Számoljuk ki a nagyobb érték közötti tárgyak különböző tömbök

szavazat
0

Van egy scoretömb, amely két tárgy: Liga és a Premier . Ezek a 2 tárgy egy sor egy listát a csapatok.

Tudtam, hogy meghatározzák a nagyobb húr, amikor scorekorábban egy tömbben tárgyak.

Ez a demo i reprodukálni, ha az összehasonlítás működik.

Ez a kód kiszámítása a magasabb érték összehasonlításával 2 tárgyakat.

const maxAverage = teams => {
  return teams.map(team => {
      return {
          team:team, 
          avg: getAverage(team)
      }
  }).reduce((a,b)=>a.avg>b.avg?a:b).team
}


<p>Stronger Team:{maxAverage([this.state.homeCity,this.state.awayCity])</p>

A probléma most az, hogy most scorevan egy tömböt a 2 tárgy ahogy már mondtam, és én próbálok változtatni a funkciót valami hasonló

const maxAverage = (league, teams) => {
  return teams.map(team => {
      return {
          team:team,
          avg: getAverage(league,team)
      }
  }).reduce((a,b)=>a.avg>b.avg?a:b).team
}

Nem vagyok képes átadni az én funkciója maxAverageparaméter az egyik két liga kijelölve, majd a 2-objektumok (csapat) összehasonlítani kívánt.

Ez a másik demo i reprodukálni a jelenlegi helyzetet.

A kérdést 24/10/2019 11:59
a forrás felhasználó
Más nyelveken...                            


4 válasz

szavazat
-1

Miért nem egyszerűen kivonat csapat, amikor a kiválasztott, megtakarítás az állami és használja ugyanazt a módszert korábban?

Válaszolt 24/10/2019 12:06
a forrás felhasználó

szavazat
0

Mivel az aláírás const maxAverage = (league, teams) => ..., alábbi kód egyezik a várt érvek (nem biztos az üzleti logika mégis):

maxAverage(
  this.state.selectedLeague,
  [this.state.selectedHomeTeam, this.state.selectedAwayTeam]
)
Válaszolt 27/10/2019 11:40
a forrás felhasználó

szavazat
0

Mi a probléma?

const scores = {'liga':[
  { day: "1", Barcelona: 1, Real: 3, Valencia: 0 },
  { day: "2", Barcelona: 4, Real: 6, Valencia: 3 },
  { day: "3", Barcelona: 7, Real: 7, Valencia: 3 },
  { day: "4", Barcelona: 7, Real: 8, Valencia: 6 }
], 'primier':[
  { day: "1", Barcelona: 1, Real: 3, Valencia: 0 },
  { day: "2", Barcelona: 4, Real: 6, Valencia: 3 },
  { day: "3", Barcelona: 7, Real: 7, Valencia: 3 },
  { day: "4", Barcelona: 7, Real: 8, Valencia: 6 }]};
const getAverage = (type, team) => {
  if (isNaN(scores[type][0][team])) return null;

  return scores[type].map(x => x[team]).reduce((a, c) => a + c) / scores[type].length;
};
getAverage('liga',this.state.homeCity);

src: https://codesandbox.io/s/recharts-examples-d9qy0

Válaszolt 27/10/2019 12:06
a forrás felhasználó

szavazat
0

Néztem a második demo, és azt hiszem, akkor két lehetősége van, hogy a helyes csapat választott, és akkor újra a korábbi getAverage módszer mind. Bármelyik

  const maxAverage = (league, teams) => {
  const currentLeague = [scores][0][league]
  return teams
    .map(team => {
      return {
        team: team,
        avg: getAverage(currentLeague, team)
      };
    })
    .reduce((a, b) => (a.avg > b.avg ? a : b)).team;
};

alternatívaként meg tudná tartani az eredeti maxAverage kódot, és hogyan hajtsák végre a liga érték, pl.

            <p>           
              Stronger Team:
              {maxAverage(scores[this.state.selectedLeague], [
                this.state.selectedHomeTeam,
                this.state.selectedAwayTeam
              ])}
            </p>
Válaszolt 29/10/2019 13:14
a forrás felhasználó

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more