說到表格排序,首先要說的就一定是數組的排序,因為數組排序是表格排序的基礎。
JavaScript為數組提供了sort()方法用於表格排序,默認情況下該方法會使Array中的數組按照ASCII碼的順序進行排列,JavaScript還為數組提供了數組倒序的方法reverse()。
看一下示例:
復制代碼 代碼如下:
function sortArray(){
var arrayTest = ["z",5,2,"a",32,3];
arrayTest.sort();
alert(arrayTest.toString()); //output:2,3,32,5,a,z
arrayTest.reverse();
alert(arrayTest.toString()); //output:z,a,5,32,3,2
}
sortArray();
呵呵,5比32還要大,很明顯這不是我們想要的結果,剛才已經說過sort()方法是按照ASCII碼的順序排序的。
其實sort()方法還允許帶一個函數類型的的參數,我們可以稱之為比較函數,當該比較函數又可以接收兩個參數,以下該函數返回值的意義:
復制代碼 代碼如下:
-1:第一個參數 小於 第二個參數
0:第一個參數 等於 第二個參數
1:第一個參數 大於 第二個參數
復制代碼 代碼如下:
/**
* 比較函數
* @param {Object} param1 要比較的參數1
* @param {Object} param2 要比較的參數2
* @return {Number} 如果param1 > param2 返回 1
* 如果param1 == param2 返回 0
* 如果param1 < param2 返回 -1
*/
function compareFunc(param1,param2){
//如果兩個參數均為字符串類型
if(typeof param1 == "string" && typeof param2 == "string"){
return param1.localeCompare(param2);
}
//如果參數1為數字,參數2為字符串
if(typeof param1 == "number" && typeof param2 == "string"){
return -1;
}
//如果參數1為字符串,參數2為數字
if(typeof param1 == "string" && typeof param2 == "number"){
return 1;
}
//如果兩個參數均為數字
if(typeof param1 == "number" && typeof param2 == "number"){
if(param1 > param2) return 1;
if(param1 == param2) return 0;
if(param1 < param2) return -1;
}
}
當我們執行arrayTest.sort(compareFunc)時我們就得到了正確的結果。
到這裡,我們不得不說明一下localeCompare()方法的用法,該方法是對字符串進行排序的方法,只有一個參數即要比較的字符串。
具體說明如下:
1、如果String對象按照字母順序排在參數中的字符串之前,返回負數
2、如果String對象按照字符順序排在參數中的字符串之後,返回正數
3、如果String對象等於參數中的字符串返回0
除此之外,localeCompare()方法還有一個獨特之處,這個獨特之處可以在其方法簽名locale(現場、當地)上得以體現,也就是說他的實現時按照區域特性來的,如果在英語體系中,他的實現可能是按照字符串升序,如果在漢語中,他的實現則是按照首字母的拼音。
呵呵,這也就是說就算我們在程序中涉及漢字,我們的排序也不回出錯。
參考以下程序:
復制代碼 代碼如下:
var testArray = ["腳","本","之","家"];
document.write(testArray.sort(
function compareFunction(param1,param2){
return param1.localeCompare(param2); //output:之,家,本,腳
}
));