javascript 數(shù)組排序與對象排序的實例
javascript 數(shù)組排序與對象排序的實例
數(shù)組排序
在使用JavaScript的時候,我們都發(fā)現(xiàn)了sort這個函數(shù)其實是按照字典順序進行排序的,比如下面的這個例子:
var ary = [2, 98, 34, 45, 78, 7, 10, 100, 99]; ary.sort(); console.log(ary);
控制臺輸出結(jié)果:
Array [ 10, 100, 2, 34, 45, 7, 78, 98, 99 ]
這個也很顯然驗證了我之前所寫的東西,上面的結(jié)果就是比較數(shù)組元素的第一位,然后按照這個1-9這個順序排列,那么我們就需要給sort函數(shù)傳入一個比較函數(shù)(在這里我還是得提及一下C語言的函數(shù)指針,簡單說就是給一個函數(shù)傳入另外一個函數(shù),而這個傳入的就像是你給出你自己的一套規(guī)則,而計算機按你這個規(guī)則執(zhí)行就好了),現(xiàn)在也是這個道理,給出一個規(guī)則來,那就請看下面的代碼:
var ary = [2, 98, 34, 45, 78, 7, 10, 100, 99]; ary.sort((a, b) => { return a-b; }); console.log(ary);
降序輸出:
ary.sort(function(a, b) { return b-a; }); console.log(ary);
傳入的函數(shù)是采用ES6的寫法,等同于:
ary.sort(function(a, b) { return a-b; });
輸出結(jié)果:
Array [ 2, 7, 10, 34, 45, 78, 98, 99, 100 ] Array [ 100, 99, 98, 78, 45, 34, 10, 7, 2 ]
對象排序
今天要說的排序?qū)ο?,像下面那樣,將多個對象放置在一個數(shù)組里面
var objArray = [ {name : 'lily', age : 22}, {name : 'kandy', age : 20}, {name : 'lindy', age : 24}, {name : 'Jone', age : 27} ];
下面就需要對它們進行排序了:
function sortObj(array, key) { return array.sort(function(a, b) { var x = a[key]; var y = b[key]; return x - y; //或者 return x > y ? 1 : (x < y ? -1 : 0); }); }
控制臺輸出結(jié)果:
以上就是javascript 數(shù)組排序與對象排序的實例的講解,大家如果有疑問可以留言討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
JS循環(huán)遍歷ul中l(wèi)i的點擊事件給選中l(wèi)i添加css樣式(示例代碼)
對于一個ul中固定的li個數(shù),當點擊其中一個li時,改變選中l(wèi)i的顏色;同時改變對應的另一個ul中l(wèi)i的顏色,怎么實現(xiàn)這個功能呢,下面小編給大家?guī)砹薺s循環(huán)遍歷ul中l(wèi)i的點擊事件,給給選中l(wèi)i添加css樣式,感興趣的朋友一起看看吧2023-07-07javascript 復雜的嵌套環(huán)境中輸出單引號和雙引號
如果簡單的嵌套一般都是外面用雙引號,則里面用單引號,反之亦同,如果特別負責的嵌套大家看下如下的方法。2009-05-05bootstrap-closable-tab可實現(xiàn)關閉的tab標簽頁插件
這篇文章主要為大家詳細介紹了bootstrap-closable-tab可實現(xiàn)關閉的tab標簽頁插件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-08-08