我现在只需获取数组的前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?
答案 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设置的,则也可以使用Lodash或Underscore。在许多情况下,这些已经是子依赖项,因此不会产生额外的负担。
结合lodash提供的ES6和_.orderBy
_.orderBy(champions, [c => c.level], ['desc']).slice(0,3)
这是一个功能强大的小实用程序。您可以为orderBy
提供多个抢七式排序键,并分别为每个键指定顺序。