js 根據(jù)json數(shù)組多個字段排序的實現(xiàn)代碼如下所示:
/**數(shù)組根據(jù)數(shù)組對象中的某個屬性值進(jìn)行排序的方法
??* 使用例子:newArray.sort(sortByArr(['number'],false)) //表示根據(jù)number屬性降序排列;若第二個參數(shù)不傳遞锋华,默認(rèn)表示升序排序
??* @param attr 排序的屬性 ['name','sex'...],根據(jù)一個字段或者多個字段排序
??* @param rev true表示升序排列,false降序排序
??* */
functionsortByArr(arr, rev) {
?if(rev == undefined) {
?rev = 1;
?} else{
?rev = (rev) ? 1 : -1;
?}
?returnfunction(a, b) {
?for(vari = 0; i < arr.length; i++) {
?let attr = arr[i]
?if(a[attr] != b[attr]) {
?if(a[attr] > b[attr]) {
?returnrev * 1;
?} else{
?returnrev * -1;
?}
?}
?}
}
}
PS:Js 中對 Json 數(shù)組的常用操作
我們首先定義一個json數(shù)組對象如下:
varpersons = [
??{name: "tina", age: 14},
??{name: "timo", age: 15},
??{name: "lily", age: 16},
??{name: "lucy", age: 16}
]
一. 根據(jù)對象屬性值得到相應(yīng)對象
//1. 獲取 name 等于 lily 的對象
varlily = persons.filter((p) => {
??returnp.name == "lily";
});
console.log(lily); //打印結(jié)果 [{name: "lily", age: 16}]
//注:filter()方法返回的是一個數(shù)組
vartwins = persons.filter((p) => {
??returnp.age == 16;
});
console.log(twins); //打印結(jié)果 [{name: "lily", age: 16},{name: "lucy", age: 16}]
二. 刪除其中一個對象
//刪除 name 等于 tina 的對象粱锐,利用splice()方法
//1. 首先我們要得到這個對象
vartina = persons.filter((p) => {
??returnp.name == "tina";
});
//2. 其次得到這個對象在數(shù)組中對應(yīng)的索引
varindex = 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 對象
vartimo = persons.filter((p) => {
??returnp.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ù)組常用操作,希望對大家有所幫助歹颓,如果大家有任何疑問請給我留言贮折,
對web開發(fā)技術(shù)感興趣的同學(xué)裤翩,歡迎私信小編加群,不管你是小白還是大牛我都?xì)g迎调榄,還有大牛整理的一套高效率學(xué)習(xí)路線和教程與您免費分享,同時每天更新視頻資料呵扛。
最后每庆,祝大家早日學(xué)有所成,拿到滿意offer今穿,快速升職加薪缤灵,走上人生巔峰