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降序排序

??* */


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ù)感興趣的同學,歡迎私信小編加群,不管你是小白還是大牛我都歡迎,還有大牛整理的一套高效率學習路線和教程與您免費分享,同時每天更新視頻資料。

最后,祝大家早日學有所成,拿到滿意offer,快速升職加薪,走上人生巔峰

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容