DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JavaScript自定義數組排序方法
JavaScript自定義數組排序方法
編輯:關於JavaScript     

本文實例講述了JavaScript自定義數組排序方法。分享給大家供大家參考。具體分析如下:

Array中有自帶的排序功能,這個使用起來比較方便,我們有一點必須清楚,就是排序的依據,如果sort不傳入參數的話,那就是按照字符編碼(Unicode編碼)的順序排序。

var a=["3","2","1"]; 
console.log(a[0].charCodeAt(0)); // 51 
console.log(a[1].charCodeAt(0)); // 50 
console.log(a[2].charCodeAt(0)); // 49 
console.log(a.sort());      // ["1", "2", "3"] 
 
var a=["3","你","他"]; 
console.log(a[0].charCodeAt(0)); // 51 
console.log(a[1].charCodeAt(0)); // 20320 
console.log(a[2].charCodeAt(0)); // 20182 
console.log(a.sort());      // ["3", "他", "你"] 
 
var a=["3","11","222"]; 
console.log(a.sort());// ["11", "222", "3"]  
           // 多個字符的時候按照第一個字符的編碼

不過我覺得sort最好用的地方在於可以自定義排序,這個在實際運用中也比較常見,比如要對對象數組排序。例如線面的一個對象數組,要根據其中的某一個字段進行排序,當然自己也可以寫個函數來完成,不過我想沒有sort來得方便。

var list = [ 
  { 
    max:3, 
    avg:2, 
    min:1 
  }, 
  { 
    max:10, 
    avg:15, 
    min:20 
  }, 
  { 
    max:8, 
    avg:5, 
    min:2 
  } 
]; 
// 根據max字段對list對象進行排序,從小到大的順序 
// x,y就是要比較的數組的單個元素,這裡就是list中的一個元素 
// 排序方法主要是要提供一個比較大小的規則,換句話說也就是要說明誰大誰小 
// 返回值為true or false 
function sortByField(x, y) { 
  return x.max - y.max; 
} 
console.log(list.sort(sortByField));

運行效果如下圖所示:

希望本文所述對大家的javascript程序設計有所幫助。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved