首頁 >web前端 >js教程 >JavaScript程式中使用localeCompare()實作數組排序和漢字排序

JavaScript程式中使用localeCompare()實作數組排序和漢字排序

高洛峰
高洛峰原創
2016-11-28 13:51:451590瀏覽

說到表格排序,首先要說的就一定是陣列的排序,因為陣列排序是表格排序的基礎。 JavaScript為數組提供了sort()方法用於表格排序,預設情況下該方法會使Array中的數組按照ASCII碼的順序進行排列,JavaScript也為數組提供了數組倒序的方法reverse()。
  來看看範例:

1         function sortArray(){
2                      arrayTest.sort();
4             alert(arrayTest. toString());     //output:2,3,32,5,a,z
5             array    //output:z,a,5,32 ,3,2
7         }
8         sortArray();

呵。其實sort()方法也允許帶一個函數型別的的參數,我們可以稱之為比較函數,當比較函數可以再接收兩個參數,以下該函數傳回值的意義:

  -1:第一個參數小於第二個參數

   0:第一個參數等於第二個參數
   1:第一個參數大於第二個參數
看一個例子:

 1         /**
 2          * 比較函數
 3          * @param {Object} } param2 要比較的參數2
 5          * @return {Number} 如果param1 > param2 返回 1
 6 如果param1 == param2 返回 0
 7          *                   */
 9         function compare 11             if(typeof param1 == "string" && typeof param2 == " string"){
12                 return param1.localeCompare(param2);    //若參數1為數字,參數2為字串
15             if(typeof param1 == "number"str & typeof param2 param1 == "number"str & typeof param2 ing "){
16                 return -1;
17          ,參數2為數字
19             if(typeof param1 == "string" && typeof param2 == "number"){
20 return 1;
21             }
22             // "number" && typeof param2 == "number"){
24                 25                 if(param1 == param2) return 0;
26     
27             }
28         }

   當我們有正確執行arrayTest.sort(compareFunc)時我們得到了正確的結果。
到這裡,我們必須說明localeCompare()方法的用法,該方法是對字串進行排序的方法,只有一個參數即要比較的字串。具體說明如下:
   1、如果String物件依照字母順序排在參數中的字串之前,傳回負數
   2、如果String物件依照字元順序排在參數中的字串之後,則傳回正數
   3、如果String物件等於參數中的字串回傳0
除此之外,localeCompare()方法還有一個獨特之處,這個獨特之處可以在其方法簽名locale(現場、當地)上得以體現,也就是說他的實現時按照區域特性來的,如果在英語體系中,他的實現可能是按照字符串升序,如果在漢語中,他的實現則是按照首字母的拼音。呵呵,這也就是說就算我們在程式中涉及漢字,我們的排序也不回出錯。
   參考以下程序:

1         var testArray = ["鄭","州","信","來源","信","息","技術","術","股","份","有", "公","公","司" ];
2         document.write(testArray.sort(
3                  return param1.localeCompare(param2);  //output:份,公,股,技術,術,司,息,限,信,信,有,源,鄭,州 
5             }
6      

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn