作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想以自定义方式对数组进行排序。
示例是学生的类(class)级别:
_.sortBy(["Junior","Senior","Freshman","Sophomore"], function(classlevel){
// ??
})
理想情况下,排序应该返回:
["Freshman","Sophomore","Junior","Senior"]
我在想我是否可以像这样提前对类(class)进行排名:
var classlevelRanked = [{ class: "Junior",
rank: 3
},{ class: "Senior",
rank: 4
},{ class: "Freshman",
rank: 1
},{ class: "Sophomore",
rank: 2
}]
然后通过以下方式应用排序:
_.sortBy(classlevelRanked, function(classlevel){
return classlevel.rank;
})
但随后我必须通过以下方式去除队伍:
.map(function(classlevel){
return classlevel["class"];
})
有没有更直接的方法来做到这一点,而无需预先对类(class)进行排名,然后再将其剥离?
最佳答案
你应该能够做这样的事情:
_.sortBy(["Junior","Senior","Freshman","Sophomore"], function(element){
var rank = {
"Junior" : 3,
"Senior" : 4,
"Freshman" :1,
"Sophomore" :2
};
return rank[element];
});
fiddle :
rank
是一个可能在其他地方有用的常量,您可以在
_.sortBy
之外定义它表达与使用
_.propertyOf
对于更具声明性的风格:
var rank = {
"Junior" : 3,
"Senior" : 4,
"Freshman" :1,
"Sophomore" :2
};
_.sortBy(["Junior","Senior","Freshman","Sophomore"], _.propertyOf(rank));
关于javascript - 如何将自定义排序应用于数组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16846403/
我是一名优秀的程序员,十分优秀!