看一下示例:
1 function sortArray(){
2 var arrayTest = ["z",5,2,"a",32,3];
3 arrayTest.sort();
4 alert(arrayTest.toString()); //output:2,3,32,5,a,z
5 arrayTest.reverse();
6 alert(arrayTest.toString()); //output:z,a,5,32,3,2
7 }
8 sortArray();
呵呵,5比32還要大,很明顯這不是我們想要的結果,剛才已經說過sort()方法是按照ASCII碼的順序排序的。其實sort()方法還允許帶一個函數(shù)類型的的參數(shù),我們可以稱之為比較函數(shù),當該比較函數(shù)又可以接收兩個參數(shù),以下該函數(shù)返回值的意義:2 var arrayTest = ["z",5,2,"a",32,3];
3 arrayTest.sort();
4 alert(arrayTest.toString()); //output:2,3,32,5,a,z
5 arrayTest.reverse();
6 alert(arrayTest.toString()); //output:z,a,5,32,3,2
7 }
8 sortArray();
-1:第一個參數(shù) 小于 第二個參數(shù)
0:第一個參數(shù) 等于 第二個參數(shù)
1:第一個參數(shù) 大于 第二個參數(shù)
看一個例子:
1 /**
2 * 比較函數(shù)
3 * @param {Object} param1 要比較的參數(shù)1
4 * @param {Object} param2 要比較的參數(shù)2
5 * @return {Number} 如果param1 > param2 返回 1
6 * 如果param1 == param2 返回 0
7 * 如果param1 < param2 返回 -1
8 */
9 function compareFunc(param1,param2){
10 //如果兩個參數(shù)均為字符串類型
11 if(typeof param1 == "string" && typeof param2 == "string"){
12 return param1.localeCompare(param2);
13 }
14 //如果參數(shù)1為數(shù)字,參數(shù)2為字符串
15 if(typeof param1 == "number" && typeof param2 == "string"){
16 return -1;
17 }
18 //如果參數(shù)1為字符串,參數(shù)2為數(shù)字
19 if(typeof param1 == "string" && typeof param2 == "number"){
20 return 1;
21 }
22 //如果兩個參數(shù)均為數(shù)字
23 if(typeof param1 == "number" && typeof param2 == "number"){
24 if(param1 > param2) return 1;
25 if(param1 == param2) return 0;
26 if(param1 < param2) return -1;
27 }
28 }
當我們執(zhí)行arrayTest.sort(compareFunc)時我們就得到了正確的結果。2 * 比較函數(shù)
3 * @param {Object} param1 要比較的參數(shù)1
4 * @param {Object} param2 要比較的參數(shù)2
5 * @return {Number} 如果param1 > param2 返回 1
6 * 如果param1 == param2 返回 0
7 * 如果param1 < param2 返回 -1
8 */
9 function compareFunc(param1,param2){
10 //如果兩個參數(shù)均為字符串類型
11 if(typeof param1 == "string" && typeof param2 == "string"){
12 return param1.localeCompare(param2);
13 }
14 //如果參數(shù)1為數(shù)字,參數(shù)2為字符串
15 if(typeof param1 == "number" && typeof param2 == "string"){
16 return -1;
17 }
18 //如果參數(shù)1為字符串,參數(shù)2為數(shù)字
19 if(typeof param1 == "string" && typeof param2 == "number"){
20 return 1;
21 }
22 //如果兩個參數(shù)均為數(shù)字
23 if(typeof param1 == "number" && typeof param2 == "number"){
24 if(param1 > param2) return 1;
25 if(param1 == param2) return 0;
26 if(param1 < param2) return -1;
27 }
28 }
到這里,我們不得不說明一下localeCompare()方法的用法,該方法是對字符串進行排序的方法,只有一個參數(shù)即要比較的字符串。具體說明如下:
1、如果String對象按照字母順序排在參數(shù)中的字符串之前,返回負數(shù)
2、如果String對象按照字符順序排在參數(shù)中的字符串之后,返回正數(shù)
3、如果String對象等于參數(shù)中的字符串返回0
除此之外,localeCompare()方法還有一個獨特之處,這個獨特之處可以在其方法簽名locale(現(xiàn)場、當?shù)?上得以體現(xiàn),也就是說他的實現(xiàn)時按照區(qū)域特性來的,如果在英語體系中,他的實現(xiàn)可能是按照字符串升序,如果在漢語中,他的實現(xiàn)則是按照首字母的拼音。呵呵,這也就是說就算我們在程序中涉及漢字,我們的排序也不回出錯。
參考以下程序:
1 var testArray = ["鄭","州","信","源","信","息","技","術","股","份","有","限","公","司" ];
2 document.write(testArray.sort(
3 function compareFunction(param1,param2){
4 return param1.localeCompare(param2); //output:份,公,股,技,術,司,息,限,信,信,有,源,鄭,州
5 }
6 ));
2 document.write(testArray.sort(
3 function compareFunction(param1,param2){
4 return param1.localeCompare(param2); //output:份,公,股,技,術,司,息,限,信,信,有,源,鄭,州
5 }
6 ));