JS根據(jù)json數(shù)組多個字段排序及json數(shù)組常用操作
js 根據(jù)json數(shù)組多個字段排序的實現(xiàn)代碼如下所示:
/**數(shù)組根據(jù)數(shù)組對象中的某個屬性值進行排序的方法 * 使用例子:newArray.sort(sortByArr(['number'],false)) //表示根據(jù)number屬性降序排列;若第二個參數(shù)不傳遞,默認表示升序排序 * @param attr 排序的屬性 ['name','sex'...],根據(jù)一個字段或者多個字段排序 * @param rev true表示升序排列,false降序排序 * */ function sortByArr(arr, rev) { if (rev == undefined) { rev = 1; } else { rev = (rev) ? 1 : -1; } return function(a, b) { for (var i = 0; i < arr.length; i++) { let attr = arr[i] if (a[attr] != b[attr]) { if (a[attr] > b[attr]) { return rev * 1; } else { return rev * -1; } } } } }
PS:Js 中對 Json 數(shù)組的常用操作
我們首先定義一個json數(shù)組對象如下:
var persons = [ {name: "tina", age: 14}, {name: "timo", age: 15}, {name: "lily", age: 16}, {name: "lucy", age: 16} ]
一. 根據(jù)對象屬性值得到相應(yīng)對象
//1. 獲取 name 等于 lily 的對象 var lily = persons.filter((p) => { return p.name == "lily"; }); console.log(lily); //打印結(jié)果 [{name: "lily", age: 16}] //注:filter()方法返回的是一個數(shù)組 var twins = persons.filter((p) => { return p.age == 16; }); console.log(twins); //打印結(jié)果 [{name: "lily", age: 16},{name: "lucy", age: 16}]
二. 刪除其中一個對象
//刪除 name 等于 tina 的對象,利用splice()方法 //1. 首先我們要得到這個對象 var tina = persons.filter((p) => { return p.name == "tina"; }); //2. 其次得到這個對象在數(shù)組中對應(yīng)的索引 var index = persons.indexOf(tina[0]); //3. 如果存在則將其刪除,index > -1 代表存在 index > -1 && persons.splice(index, 1); console.log(persons); //打印結(jié)果 [{name: "timo", age: 15}, {name: "lily", age: 16}, {name: "lucy", age: 16}]
三. 修改其中一個對象的屬性值
//將 name 等于 timo 的 age 修改為 20 //1. 得到 timo 對象 var timo = persons.filter((p) => { return p.name == "timo"; }); //2. 修改age timo[0].age = 20;
四. 往數(shù)組中添加一個對象
//這個最簡單了 persons.push({name: "similar", age: 18});
——注: 以上的所有操作都會對原數(shù)組產(chǎn)生直接影響。
總結(jié)
以上所述是小編給大家介紹的JS根據(jù)json數(shù)組多個字段排序及json數(shù)組常用操作,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
JS/jQuery實現(xiàn)默認顯示部分文字點擊按鈕顯示全部內(nèi)容
默認顯示部分文字,點擊按鈕顯示全部,類似這樣的功能在一些特殊的地方會見到吧,下面與大家分享下JS、jQuery如何實現(xiàn),感興趣的朋友可以參考下哈,希望對你有所幫助2013-05-05用javascript實現(xiàn)分割提取頁面所需內(nèi)容
用javascript實現(xiàn)分割提取頁面所需內(nèi)容...2007-05-05javascript中打印當(dāng)前的時間實現(xiàn)思路及代碼
打印當(dāng)前的時間的方法有很多,在本文為大家詳細介紹下使用javascript是如何做到的,具體實現(xiàn)如下,感興趣的朋友可以參考下2013-12-12文本框只能輸入數(shù)字的js代碼(含小數(shù)點)
下面小編就為大家?guī)硪黄谋究蛑荒茌斎霐?shù)字的js代碼(含小數(shù)點)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-07-07