多維數組按指定項迭代排序
比如[[[1, 2], [2, 10],[2, 0], ,[1, 4], [4, 3]]這樣的二維數組
如果先按第一項排序,就得到[[1,2],[1,4],[2,10],[2,0],[4,3]], 然後再按照第二項排序。
或者先按照第二項,再按照第一項也是一樣。
function sortArray(arr, index) {
/*
@arr: 待排序的多維數組
*/
var temp_arr = arr;
if(arguments.length == 1) {
return arr;
}
if(arguments.length == 2) {
return arr.sort(function (left, right) {
return left[index] > right[index] ? true : false;
})
}
for(var i=1; i< arguments.length; ++i) {
temp_arr = sortArray(temp_arr, arguments[i]);
}
return temp_arr;
}
console.log(sortArray([[1, 2], [2, 10], [2, 0], [1, 4], [4, 3]], 0));
console.log(sortArray([[1, 2], [2, 10], [2, 0], [1, 4], [4, 3]], 1));
console.log(sortArray([[1, 2], [2, 10], [2, 0], [1, 4], [4, 3]], 0, 1));
console.log(sortArray([[1, 2], [2, 10], [2, 0], [1, 4], [4, 3]], 1, 0));
測試的時候需要注意,因爲Array是引用類型的,所以需要多申請幾個變量。