我有一些像这样的 50 多个名字的数组。
["dan", "ryan", "bob", "steven", "corbin"]
["bob", "dan", "steven", "corbin"]
我有另一个顺序正确的数组。请注意,上面的第二个数组并不包含所有名称,但我仍然希望它遵循以下顺序:
["ryan", "corbin", "dan", "steven", "bob"]
它没有逻辑顺序,它们只是按这个顺序排列。对我来说有意义的是将每个数组与正确排序的数组进行比较。我想我看到有人用 PHP 做这个,但我找不到 JavaScript 解决方案。有谁知道如何做到这一点?我已经尝试了几个小时,但我被难住了。
Use 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); // ["corbin", "dan", "steven", "bob"]
对于大型数组来说,每次都搜索参考数组效率很低。如果这是一个问题,您可以将其转换为将名称映射到位置的对象:
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);
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)