javascript 數組排序函數sort和reverse使用介紹_javascript技巧

來源:互聯網
上載者:User
首先我們先說一下reverse方法。

reverse 方法將一個 Array 對象中的元素位置進行反轉。在執行過程中,這個方法並不會建立一個新的 Array 對象。

例如:
複製代碼 代碼如下:

var array1 = ['a','cc','bb','hello',false,0,3];
var array2 = [3,5,2,1,7,9,10,13];
array1.reverse();
array2.reverse();
alert(array1);
alert(array2);

如果數組中只包含數字,那麼數字將降序排列,如果數組中還包含其他類型,就將數組反轉並返回數組。

sort 方法

返回一個元素已經進行了排序的 Array 對象。
複製代碼 代碼如下:

arrayobj.sort(sortfunction)

參數

arrayObj

必選項。任意 Array 對象。

sortFunction

可選項。是用來確定元素順序的函數的名稱。如果這個參數被省略,那麼元素將按照 ASCII 字元順序進行升序排列。

sort 方法將 Array 對象進行適當的排序;在執行過程中並不會建立新的 Array 對象。

如果為 sortfunction 參數提供了一個函數,那麼該函數必須返回下列值之一:

負值,如果所傳遞的第一個參數比第二個參數小。
零,如果兩個參數相等。
正值,如果第一個參數比第二個參數大。

例1:()
複製代碼 代碼如下:

var a, l; // 聲明變數。
a = ["X" ,"y" ,"d", "Z", "v","m","r",false,0];
l = a.sort(); // 排序數組。
alert(l); // 返回排序的數組。

這個例子裡沒有傳入比較函數那麼元素將按照 ASCII 字元順序進行升序排列,另外這個數組中包含了多種類型的資料,所以即使傳入了比較函數,它依然按照ASCII 字元順序進行升序排列。

例如
複製代碼 代碼如下:

var a, l; // 聲明變數。
a = ["X" ,"y" ,"d", "Z", "v","m","r",false,0];
l = a.sort(); // 排序數組。
alert(l); // 返回排序的數組。
ll = a.sort(compack);
alert(ll);//返回與上面一樣
function compack(a,b){
return a-b;
}

當我們需要對數字排序的時候可以使用sort方法,只要給它傳入一個比較函數就可以輕鬆的升序和降序。

升序:
複製代碼 代碼如下:

var a, l; // 聲明變數。
a = [6,8,9,5.6,12,17,90];
l = a.sort(compack); // 排序數組。
alert(l); // 返回排序的數組。

function compack(a,b){
return a-b;
}

降序:
複製代碼 代碼如下:

var a, l; // 聲明變數。
a = [6,8,9,5.6,12,17,90];
l = a.sort(compack); // 排序數組。
alert(l); // 返回排序的數組。

function compack(a,b){
return b-a;
}

在比較函數裡升序返回a-b,降序返回b-a。
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.