多維數組按照指定項排序

多維數組按指定項迭代排序

比如[[[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是引用類型的,所以需要多申請幾個變量。



發佈了88 篇原創文章 · 獲贊 37 · 訪問量 12萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章