我有以下结构:
var participant0 = {
name : "",
nickname : "",
number "99999"
} ;
var participant1 = {
name : "bbb",
nickname : "",
} ;
var participant2 = {
name : "",
nickname : "aaa"
} ;
var participant3 = {
name : "ccc",
nickname : ""
} ;
我有一个包含结构实例的数组:
var array = [participant0, participant3, participant1, participant2];
我想按字母顺序排列这个数组.名字第一,昵称第二名.如果这两个键不存在,我想检查数字键并将此元素放在排序列表的末尾.
预期结果 :
var array = [participant2, participant1, participant3, participant0];
(按“aaa”,“bbb”,“ccc”,“9999”排序对象)
下面的代码工作正常,按名称或昵称排序,但我不知道如果有数字键,如何将项目放在排序列表的末尾:
fav_list.sort(function(x, y) {
return (x.participant.name || x.participant.nickname).localeCompare(y.participant.name || y.participant.nickname);
});
最佳答案 我认为应该这样做,请参阅代码中的注释:
fav_list.sort(function(x, y) {
var xvalue = x.participant.name || x.participant.nickname;
var yvalue = y.participant.name || y.participant.nickname;
// By name if both have names
if (xvalue && yvalue) {
return xvalue.localeCompare(yvalue);
}
// Names always come before numbers
if (xvalue) {
return -1;
}
if (yvalue) {
return 1
}
// Otherwise compare numbers
return (x.participant.number || 0) - (y.participant.number || 0);
});
您可能希望使用最后一行中的默认数字(零).
请注意,您显示的数组与该代码不完全匹配,因为该数组直接使用参与者,但代码期望参与者位于对象的参与者属性上.
带有轻微调整数组的实例,以及一种方便的方式来说明我们最终的订单:
var participant0 = {
name: "",
nickname: "",
number: "99999",
debug: 0
};
var participant1 = {
name: "bbb",
nickname: "",
debug: 1
};
var participant2 = {
name: "",
nickname: "aaa",
debug: 2
};
var participant3 = {
name: "ccc",
nickname: "",
debug: 3
};
var array = [
{
participant: participant0
},
{
participant: participant3
},
{
participant: participant1
},
{
participant: participant2
}
];
array.sort(function(x, y) {
var xvalue = x.participant.name || x.participant.nickname;
var yvalue = y.participant.name || y.participant.nickname;
// By name if both have names
if (xvalue && yvalue) {
return xvalue.localeCompare(yvalue);
}
// Names always come before numbers
if (xvalue) {
return -1;
}
if (yvalue) {
return 1
}
// Otherwise compare numbers
return (x.participant.number || 0) - (y.participant.number || 0);
});
array.forEach(function(entry) {
snippet.log(entry.participant.debug);
});
<!-- Script provides the `snippet` object, see http://meta.stackexchange.com/a/242144/134069 -->
<script src="http://tjcrowder.github.io/simple-snippets-console/snippet.js"></script>