JS中使用sort結合localeCompare實現中文排序執行個體,sortlocalecompare

來源:互聯網
上載者:User

JS中使用sort結合localeCompare實現中文排序執行個體,sortlocalecompare

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

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:之,家,本,腳
             }
         ));


js中用localeCompare()方法 比較字串時,只比較第一個字元?

stringVar.localeCompare(stringExp)其中stringVar是必選項。一個 String 對象後文字。
stringExp是必選項。將與 stringVar 進行比較的字串。

localeCompare 可以對 stringVar 和 stringExp 進行一個區分地區設定的字串比較並返回 –1、0 或 +1,這取決於系統中預設地區設定的排序。如果 stringVar 排序在 stringExp 之前,那麼 localeCompare 返回 –1;如果 stringVar 排序在 stringExp 之後,則返回 +1。如果傳回值為 0,那就說明這兩個字串是相同的。
 
使用localeCompare按照漢字拼音排序的結不美觀不太准怎措置?

var citys = ['北京-b','上海-s','廣州-g','深圳-s','南京-n','姑蘇-s','杭州-h','濟南-j','青島-q','武漢-w','瀋陽-sh','成都-ch','天津-t','重慶-ch','西安-x','鄭州-zh','石家莊-sh','長沙-ch','長春-ch','合肥-h','福州-f']; function sortRule(a,b) { return a.replace(/.*\-(.+)$/, '$1') > b.replace(/.*\-(.+)$/, '$1'); } window.onload = function(){ alert(citys.sort(sortRule)); }在safari瀏覽器上得不到正確的排序。。。firefox可以
 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.