我有几个像这样的50个名字的数组.
["dan", "ryan", "bob", "steven", "corbin"]
["bob", "dan", "steven", "corbin"]
我有另一个具有正确顺序的数组.请注意,上面的第二个数组不包含所有名称,但我仍然希望它遵循以下顺序:
["ryan", "corbin", "dan", "steven", "bob"]
它没有逻辑顺序,它们只是按此顺序排列.对我来说有意义的是将每个数组与正确排序的数组进行比较.我想我看到有些人用PHP做这件事,但我找不到JavaScript解决方案.有谁知道怎么做?我已经尝试了几个小时,我很难过.
解决方法:
使用indexOf()获取引用数组中每个元素的位置,并在比较函数中使用它.
var reference_array = ["ryan", "corbin", "dan", "steven", "bob"];
var array = ["bob", "dan", "steven", "corbin"];
array.sort(function(a, b) {
return reference_array.indexOf(a) - reference_array.indexOf(b);
});
console.log(array);
每次搜索参考数组对于大型数组来说效率低.如果这是一个问题,您可以将其转换为将名称映射到位置的对象:
var reference_array = ["ryan", "corbin", "dan", "steven", "bob"];
reference_object = {};
for (var i = 0; i < reference_array.length; i++) {
reference_object[reference_array[i]] = i;
}
var array = ["bob", "dan", "steven", "corbin"];
array.sort(function(a, b) {
return reference_object[a] - reference_object[b];
});
console.log(array);