如何通过React.js中的map按最大值对对象数组进行排序?

时间:2020-04-04 06:52:44

标签: reactjs ecmascript-6

我正在尝试从API数据中打印值,目前,我能够按字母顺序打印。现在,我想按最大值到最小值的顺序打印。我想以最多的案例到最少的案例显示数组数据。但是,我很难找到解决方法。这是我的代码:

API link

import React from 'react'
import Table from 'react-bootstrap/Table';

const Result = (props) => {
  console.log('props value is:' + props.data)
  let { searchCheck, searchValue } = props;


  let update = props.data.map((item) => {

    const { countryInfo, country, cases, deaths, recovered, active, casesPerOneMillion } = item;
    return (
      (searchCheck) ? country.toUpperCase().includes(searchValue.toUpperCase()) ?
        <tbody>
          <tr key={countryInfo._id}>
            <td><img style={{ height: '25px', width: '50px' }} src={countryInfo.flag} /></td>
            <td>{country}</td>
            <td>{cases}</td>
            <td>{active}</td>
            <td>{recovered}</td>
            <th>{casesPerOneMillion}</th>
            <td>{deaths}</td>
          </tr>
        </tbody> :
        '' :
        <tbody>
          <tr key={countryInfo._id}>
            <td><img style={{ height: '25px', width: '50px' }} src={countryInfo.flag} /></td>
            <td>{country}</td>
            <td>{cases}</td>
            <td>{active}</td>
            <td>{recovered}</td>
            <th>{casesPerOneMillion}</th>
            <td>{deaths}</td>
          </tr>
        </tbody>
    )
  })
  return (
    <div>
      <Table striped bordered hover variant="dark">
        <thead>
          <tr>

            <th>Flag</th>
            <th>Country</th>
            <th>Cases</th>
            <th>Active</th>
            <th>Recovered</th>
            <th>Cases per one Million</th>
            <th>Deaths</th>


          </tr>
        </thead>
        {update}
      </Table>
    </div>
  )
}
export default Result;

1 个答案:

答案 0 :(得分:0)

您可以像这样简单地进行操作:

var sortedData = [...data].sort((a, b) => b.cases - a.cases)

在这里,data实际上是您正在使用的props.data

演示:

(async() => {
  let response = await fetch('https://corona.lmao.ninja/countries?sort=country');
  let data = await response.json(); // read response body as json
  var sortedData = [...data].sort((a, b) => b.cases - a.cases)  
  
  // Showing only top 10 country case counts
  console.log(sortedData.slice(0, 10).map(({country, cases}) => ({ country, cases})));
})();
.as-console-wrapper { max-height: 100% !important; top: 0; }