DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> Sort()函數的多種用法
Sort()函數的多種用法
編輯:關於JavaScript     

sort() 方法用於對數組的元素進行排序。包含於頭文件algorithm

語法

arrayObject.sort(sortby)

參數 描述 sortby 可選。規定排序順序。必須是函數。

返回值

對數組的引用。請注意,數組在原數組上進行排序,不生成副本。

一、默認情況

在默認情況下, sort() 方法按升序排列數組項。為了實現排序, sort() 方法會調用每個數組項的 toString() 轉型方法,然後比較得到的字符串,已確定如何排序。如下:

var values = ["orange","apple","banana"];
values.sort();
console.log(values);//結果["apple", "banana", "orange"]

但是,即使數組中的每一項都是數值,sort() 方法比較的也是字符串,如下:

var values = [,,,,];
values.sort();
console.log(values);//結果[, , , , ]

二、對數值進行排序

sort() 方法可以接收一個比較函數作為參數。

比較函數接收兩個參數,如果第一個參數應該位於第二參數之前則返回一個負數,如果兩個參數相等則返回0,如果第一個參數位於第二個之後則返回一個正數。

function compare(a, b){
return (a - b);
}//按升序排列的比較函數
var values = [,,,,];
values.sort(compare);
console.log(values);//結果[, , , , ]

三、根據某個對象屬性對數組進行排序

先定義一個函數,它接收一個屬性名,然後根據這個屬性名來創建一個比較函數。下面是這個函數的定義:

function createComparisonFunction(propertyName){
return function(object, object){
var a = object[propertyName];
var b = object[propertyName];
if(a < b){
return -;
}else if(a > b){
return ;
}else{
return ;
}
}
}//返回一個根據屬性名創建的按升序排列的比較函數

在內部函數接收到propertyName參數後,它會使用方括號表示法來取得給定屬性的值。

上面這個函數可以在像在下面例子中這樣使用。

var data = [{name:"Lily", age: }, {name:"Judy", age: }];
data.sort(createComparisonFunction("name"));
console.log(data[].name);//Judy
data.sort(createComparisonFunction("age"));
console.log(data[].name);//Lily

以上內容是小編給大家介紹的Sort()函數的多種用法,希望對大家以上幫助!

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