按属性排序数组

时间:2015-03-04 11:48:03

标签: javascript reactjs

我现在只需获取数组的前3个对象并映射它们:

<ul className="ItemSearchList"> 
  { 
    champions.slice(0,3).map(function(champ){
      return (
        <li key={champ.id} >
          <div className="media">
            <div className="media-left">
              <a href="#">
                <img className="media-object" src={"http://ddragon.leagueoflegends.com/cdn/5.2.1/img/champion/" + champ.key  + ".png"} />
              </a>
            </div>
            <div className="media-body" >
              <h4 className="media-heading">{champ.name}</h4>
              <div>
                something
              </div>
            </div>
          </div>
        </li>
      )
    }) 
  }
</ul>

每个champ都有一个level属性(champ.level)。

如何将输出排序为champ.level descending并切片前3?

3 个答案:

答案 0 :(得分:101)

使用Array.prototype.sort()和自定义比较功能首先执行降序排序:

champions.sort(function(a, b) { return b.level - a.level }).slice(...

ES6更好:

champions.sort((a, b) => b.level - a.level).slice(...

答案 1 :(得分:12)

编写自己的比较函数:

function compare(a,b) {
  if (a.level < b.level)
     return -1;
  if (a.level > b.level)
    return 1;
  return 0;
}

使用它:

champions.sort(compare).slice(0,3).map(function(champ) {

答案 2 :(得分:3)

纯JS解决方案很好。但是,如果您的项目是通过npm设置的,则也可以使用LodashUnderscore。在许多情况下,这些已经是子依赖项,因此不会产生额外的负担。

结合lodash提供的ES6和_.orderBy

_.orderBy(champions, [c => c.level], ['desc']).slice(0,3)

这是一个功能强大的小实用程序。您可以为orderBy提供多个抢七式排序键,并分别为每个键指定顺序。