首頁  >  文章  >  web前端  >  JS中使用sort結合localeCompare實作中文排序實例_javascript技巧

JS中使用sort結合localeCompare實作中文排序實例_javascript技巧

WBOY
WBOY原創
2016-05-16 16:41:151480瀏覽

說到表格排序,首先要說的就一定是陣列的排序,因為陣列排序是表格排序的基礎。

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
           *                                *                               */
          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              }
         }


當我們執行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:之,家,本,腳
             }
         ));
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn