您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關javascript中數組排序與對象排序的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
javascript 數組排序與對象排序的實例
數組排序
在使用JavaScript的時候,我們都發現了sort這個函數其實是按照字典順序進行排序的,比如下面的這個例子:
var ary = [2, 98, 34, 45, 78, 7, 10, 100, 99]; ary.sort(); console.log(ary);
控制臺輸出結果:
Array [ 10, 100, 2, 34, 45, 7, 78, 98, 99 ]
這個也很顯然驗證了我之前所寫的東西,上面的結果就是比較數組元素的第一位,然后按照這個1-9這個順序排列,那么我們就需要給sort函數傳入一個比較函數(在這里我還是得提及一下C語言的函數指針,簡單說就是給一個函數傳入另外一個函數,而這個傳入的就像是你給出你自己的一套規則,而計算機按你這個規則執行就好了),現在也是這個道理,給出一個規則來,那就請看下面的代碼:
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);
傳入的函數是采用ES6的寫法,等同于:
ary.sort(function(a, b) { return a-b; });
輸出結果:
Array [ 2, 7, 10, 34, 45, 78, 98, 99, 100 ] Array [ 100, 99, 98, 78, 45, 34, 10, 7, 2 ]
對象排序
今天要說的排序對象,像下面那樣,將多個對象放置在一個數組里面
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); }); }
控制臺輸出結果:
關于“javascript中數組排序與對象排序的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。