JavaScript自定義數(shù)組排序方法
本文實(shí)例講述了JavaScript自定義數(shù)組排序方法。分享給大家供大家參考。具體分析如下:
Array中有自帶的排序功能,這個(gè)使用起來比較方便,我們有一點(diǎn)必須清楚,就是排序的依據(jù),如果sort不傳入?yún)?shù)的話,那就是按照字符編碼(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"] // 多個(gè)字符的時(shí)候按照第一個(gè)字符的編碼
不過我覺得sort最好用的地方在于可以自定義排序,這個(gè)在實(shí)際運(yùn)用中也比較常見,比如要對(duì)對(duì)象數(shù)組排序。例如線面的一個(gè)對(duì)象數(shù)組,要根據(jù)其中的某一個(gè)字段進(jìn)行排序,當(dāng)然自己也可以寫個(gè)函數(shù)來完成,不過我想沒有sort來得方便。
var list = [ { max:3, avg:2, min:1 }, { max:10, avg:15, min:20 }, { max:8, avg:5, min:2 } ]; // 根據(jù)max字段對(duì)list對(duì)象進(jìn)行排序,從小到大的順序 // x,y就是要比較的數(shù)組的單個(gè)元素,這里就是list中的一個(gè)元素 // 排序方法主要是要提供一個(gè)比較大小的規(guī)則,換句話說也就是要說明誰大誰小 // 返回值為true or false function sortByField(x, y) { return x.max - y.max; } console.log(list.sort(sortByField));
運(yùn)行效果如下圖所示:
希望本文所述對(duì)大家的javascript程序設(shè)計(jì)有所幫助。
- Js數(shù)組排序函數(shù)sort()介紹
- JS數(shù)組排序技巧匯總(冒泡、sort、快速、希爾等排序)
- js sort 二維數(shù)組排序的用法小結(jié)
- js中數(shù)組排序sort方法的原理分析
- javascript 數(shù)組排序函數(shù)sort和reverse使用介紹
- JavaScript sort數(shù)組排序方法和自我實(shí)現(xiàn)排序方法小結(jié)
- JavaScript數(shù)組排序reverse()和sort()方法詳解
- JavaScript對(duì)象數(shù)組排序函數(shù)及六個(gè)用法
- javascript 數(shù)組排序與對(duì)象排序的實(shí)例
- JavaScript對(duì)象數(shù)組排序?qū)嵗椒\析
- JS簡單數(shù)組排序操作示例【sort方法】
相關(guān)文章
基于JavaScript實(shí)現(xiàn)網(wǎng)頁版羊了個(gè)羊游戲
最近羊了個(gè)羊火的不得了,這篇文章主要為大家介紹了如何利用JS實(shí)現(xiàn)個(gè)網(wǎng)頁版羊了個(gè)羊游戲,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-09-09js簡單倒計(jì)時(shí)實(shí)現(xiàn)代碼
這篇文章主要介紹了js簡單倒計(jì)時(shí)實(shí)現(xiàn)代碼,涉及JavaScript時(shí)間與日期的相關(guān)運(yùn)算技巧,需要的朋友可以參考下2016-04-04javascript實(shí)現(xiàn)獲取圖片大小及圖片等比縮放的方法
這篇文章主要介紹了javascript實(shí)現(xiàn)獲取圖片大小及圖片等比縮放的方法,涉及javascript針對(duì)圖形圖像相關(guān)屬性獲取與修改相關(guān)操作技巧,需要的朋友可以參考下2016-11-11JavaScript中字符串與Unicode編碼互相轉(zhuǎn)換的實(shí)現(xiàn)方法
這篇文章主要介紹了JavaScript中字符串與Unicode編碼互相轉(zhuǎn)換的實(shí)現(xiàn)方法涉及JavaScript編碼、數(shù)據(jù)類型等的轉(zhuǎn)換技巧,需要的朋友可以參考下2015-12-12一文教你如何實(shí)現(xiàn)localStorage的過期機(jī)制
要知道localStorage本身并沒有提供過期機(jī)制,既然如此那就只能我們自己來實(shí)現(xiàn)了,這篇文章主要給大家介紹了關(guān)于如何實(shí)現(xiàn)localStorage過期機(jī)制的相關(guān)資料,需要的朋友可以參考下2022-02-02JS onmousemove鼠標(biāo)移動(dòng)坐標(biāo)接龍DIV效果實(shí)例
這篇文章主要介紹了JS onmousemove鼠標(biāo)移動(dòng)坐標(biāo)接龍DIV效果實(shí)例,有需要的朋友可以參考一下2013-12-12