亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解數組Array.sort()排序的方法

 更新時間:2020年05月09日 22:09:00   作者:陌年古城  
JavaScript中數組的sort()方法主要用于對數組的元素進行排序。其中,sort()方法有一個可選參數。接下來通過本文給大家介紹數組Array.sort()排序的方法,需要的朋友參考下

數組sort排序

sort比較次數,sort用法,sort常用

描述

方法sort()將在原數組上對數組元素進行排序,即排序時不創(chuàng)建新的數組副本。如果調用方法sort()時沒有使用參數,將按字母順序(更為精確地說,是按照字符編碼的順序)對數組中的元素進行排序。要實現(xiàn)這一點,首先應把數組的元素都轉換成字符串(如果有必要的話),以便進行比較。

如果想按照別的順序進行排序,就必須提供比較函數,該函數要比較兩個值,然后返回一個用于說明這兩個值的相對順序的數字。比較函數應該具有兩個參數a和b,其返回值如下:

如果根據你的評判標準,a小于b,在排序后的數組中a應該出現(xiàn)在b之前,就返回一個小于0的值。

如果a等于b,就返回0。

如果a大于b,就返回一個大于0的值。

注意,數組中undefined的元素都排列在數組末尾。即使你提供了自定義的排序函數也是這樣,因為undefined值不會被傳遞給你提供的orderfunc。

JavaScript中數組的sort()方法主要用于對數組的元素進行排序。其中,sort()方法有一個可選參數。但是,此參數必須是函數。 數組在調用sort()方法時,如果沒有傳參將按字母順序(字符編碼順序)對數組中的元素進行排序,如果想按照其他標準進行排序,就需要進行傳一個參數且為函數,該函數要比較兩個值,并且會返回一個用于說明這兩個值的相對順序的數字。

1、對數字數組進行由小到大的順序進行排序。

代碼:

var arr = [22,12,3,43,56,47,4];
arr.sort();
console.log(arr); // [12, 22, 3, 4, 43, 47, 56]
arr.sort(function (m, n) {
 if (m < n) return -1
 else if (m > n) return 1
 else return 0
});
console.log(arr); // [3, 4, 12, 22, 43, 47, 56]

2、對字符串數組執(zhí)行不區(qū)分大小寫的字母表排序。

代碼:

var arr = ['abc', 'Def', 'BoC', 'FED'];
console.log(arr.sort()); // ["BoC", "Def", "FED", "abc"]
console.log(arr.sort(function(s, t){
 var a = s.toLowerCase();
 var b = t.toLowerCase();
 if (a < b) return -1;
 if (a > b) return 1;
 return 0;
})); // ["abc", "BoC", "Def", "FED"]

3、對包含對象的數組排序,要求根據對象中的年齡進行由大到小的順序排列

代碼:

var arr = [{'name': '張三', age: 26},{'name': '李四', age: 12},{'name': '王五', age: 37},{'name': '趙六', age: 4}];
var objectArraySort = function (keyName) {
 return function (objectN, objectM) {
 var valueN = objectN[keyName]
 var valueM = objectM[keyName]
 if (valueN < valueM) return 1
 else if (valueN > valueM) return -1
 else return 0
 }
}
arr.sort(objectArraySort('age'))
console.log(arr) // [{'name': '王五', age: 37},{'name': '張三', age: 26},{'name': '李四', age: 12},{'name': '趙六', age: 4}]

以上所述是小編給大家介紹的JavaScript中數組Array.sort()排序方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • Bootstrap打造一個左側折疊菜單的系統(tǒng)模板(二)

    Bootstrap打造一個左側折疊菜單的系統(tǒng)模板(二)

    這篇文章主要介紹了Bootstrap打造一個左側折疊菜單的系統(tǒng)模板(二)的相關資料,需要的朋友可以參考下
    2016-05-05
  • 詳解TypeScript的基礎類型

    詳解TypeScript的基礎類型

    這篇文章主要為大家介紹了TypeScript的基礎類型,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • js使用swiper實現(xiàn)層疊輪播效果實例代碼

    js使用swiper實現(xiàn)層疊輪播效果實例代碼

    這篇文章主要給大家介紹了關于js使用swiper實現(xiàn)層疊輪播效果的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-12-12
  • Boostrap模態(tài)窗口的學習小結

    Boostrap模態(tài)窗口的學習小結

    Bootstrap Modals(模態(tài)框)是使用定制的 Jquery 插件創(chuàng)建的。它可以用來創(chuàng)建模態(tài)窗口豐富用戶體驗,或者為用戶添加實用功能。您可以在 Modals(模態(tài)框)中使用 Popover(彈出框)和 Tooltip(工具提示插件)
    2016-03-03
  • JS實現(xiàn)控制表格行文本對齊的方法

    JS實現(xiàn)控制表格行文本對齊的方法

    這篇文章主要介紹了JS實現(xiàn)控制表格行文本對齊的方法,涉及javascript操作表格樣式的相關技巧,需要的朋友可以參考下
    2015-03-03
  • 原生JS實現(xiàn)網絡彩票投注效果

    原生JS實現(xiàn)網絡彩票投注效果

    分享一個最近模仿市面彩票系統(tǒng)寫個小案例,沒有使用任何后臺,從投注到開獎再到返獎都是用原生JS實現(xiàn)的。
    2016-09-09
  • javascript每日必學之多態(tài)

    javascript每日必學之多態(tài)

    javascript每日必學之多態(tài),介紹了有關多態(tài)的相關內容,感興趣的小伙伴們可以參考一下
    2016-02-02
  • Bootstrap表單組件教程詳解

    Bootstrap表單組件教程詳解

    表單常見的元素主要包括:文本輸入框、下拉選擇框、單選框、復選框、文本域、按鈕等。接下來通過本文給大家介紹Bootstrap表單組件教程,感興趣的朋友一起學習吧
    2016-04-04
  • JavaScript?Object.defineProperty與proxy代理模式的使用詳細分析

    JavaScript?Object.defineProperty與proxy代理模式的使用詳細分析

    這篇文章主要介紹了JavaScript?Object.defineProperty與proxy代理模式的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-10-10
  • alert和confirm功能介紹

    alert和confirm功能介紹

    這篇文章主要為大家介紹了alert和confirm的功能,需要的朋友可以參考下
    2014-05-05

最新評論