JS中數(shù)組重排序方法
1.數(shù)組中已存在兩個可直接用來重排序的方法:reverse()和sort()。
reverse()和sort()方法的返回值是經(jīng)過排序后的數(shù)組。reverse()方法會反轉數(shù)組項的順序:
var values=[1,2,3,4,5]; values.reverse(); alert(values); //5,4,3,2,1
在默認情況下,sort()方法按升序排列數(shù)組,sort()方法會調用每個數(shù)組項的toString()轉型方法,然后比較得到字符串,確定如何排序。即使數(shù)組中的每一項都是數(shù)值,sort()方法比較的也是字符串:
var values = [0,1,5,10,15]; values.sort(); alert(values); //0,1,10,15,5
因此,sort()方法可以接收一個比較函數(shù)作為參數(shù)。
function compare(value1,value2){
if (value1 < value2){
return -1;
}else if (value1 > value2){
return 1;
}else{
return 0;
}
}
此比較函數(shù)可適用于大多數(shù)數(shù)據(jù)類型,只要將其作為參數(shù)傳遞給sort()方法即可:
var values = [0,1,3,7,9,15]; values.sort(compare); alert(values); //0,1,3,7,9,15
也可通過比較函數(shù)產(chǎn)生降序排序,只需交換函數(shù)返回值即可:
function compare (value1, value2){
if (value1<value2){
return 1;
}else if {
return -1;
}else{
return 0;
}
}
sort()函數(shù)的排序條件是:
參數(shù)大于0,arr的相鄰兩個元素交換位置;
參數(shù)小于0,arr的相鄰兩個元素不交換位置;
參數(shù)等于0,arr的相鄰兩個元素大小相等;所以compare自定義函數(shù)必須返回一個數(shù)值。
2.對于數(shù)值類型或者valueOf()方法會返回數(shù)值類型的對象類型。
可使用一個更簡單的比較函數(shù)。此函數(shù)只要第二個值減第一個值即可。
function compare (value1,value2){
return value2 - value1;
}
以上所述是小編給大家介紹的JS中數(shù)組重排序方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- JavaScript實現(xiàn)鏈表插入排序和鏈表歸并排序
- JavaScript排序算法動畫演示效果的實現(xiàn)方法
- js利用appendChild對<li>標簽進行排序的實現(xiàn)方法
- 淺談js控制li標簽排序問題 js調用php函數(shù)的方法
- js基本算法:冒泡排序,二分查找的簡單實例
- javascript數(shù)組對象常用api函數(shù)小結(連接,插入,刪除,反轉,排序等)
- AngularJS 過濾與排序詳解及實例代碼
- JavaScript算法系列之快速排序(Quicksort)算法實例詳解
- JavaScript 冒泡排序和選擇排序的實現(xiàn)代碼
- 基于javascript實現(xiàn)的快速排序
相關文章
JavaScript中object和Object的區(qū)別(詳解)
下面小編就為大家?guī)硪黄狫avaScript中object和Object的區(qū)別(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02

