JS根據(jù)json數(shù)組多個字段排序及json數(shù)組常用操作

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今穿,快速升職加薪缤灵,走上人生巔峰

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市蓝晒,隨后出現(xiàn)的幾起案子腮出,更是在濱河造成了極大的恐慌,老刑警劉巖芝薇,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件胚嘲,死亡現(xiàn)場離奇詭異,居然都是意外死亡洛二,警方通過查閱死者的電腦和手機(jī)馋劈,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來晾嘶,“玉大人妓雾,你說我怎么就攤上這事±萦兀” “怎么了械姻?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長机断。 經(jīng)常有香客問我楷拳,道長绣夺,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任唯竹,我火速辦了婚禮乐导,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘浸颓。我一直安慰自己物臂,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布产上。 她就那樣靜靜地躺著棵磷,像睡著了一般。 火紅的嫁衣襯著肌膚如雪晋涣。 梳的紋絲不亂的頭發(fā)上仪媒,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天,我揣著相機(jī)與錄音谢鹊,去河邊找鬼算吩。 笑死,一個胖子當(dāng)著我的面吹牛佃扼,可吹牛的內(nèi)容都是我干的偎巢。 我是一名探鬼主播,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼兼耀,長吁一口氣:“原來是場噩夢啊……” “哼压昼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起瘤运,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤窍霞,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后拯坟,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體但金,經(jīng)...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年似谁,在試婚紗的時候發(fā)現(xiàn)自己被綠了傲绣。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,731評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡巩踏,死狀恐怖秃诵,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情塞琼,我是刑警寧澤菠净,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響毅往,放射性物質(zhì)發(fā)生泄漏牵咙。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一攀唯、第九天 我趴在偏房一處隱蔽的房頂上張望洁桌。 院中可真熱鬧,春花似錦侯嘀、人聲如沸另凌。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽吠谢。三九已至,卻和暖如春诗茎,著一層夾襖步出監(jiān)牢的瞬間工坊,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工敢订, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留王污,地道東北人。 一個月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓楚午,卻偏偏與公主長得像玉掸,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子醒叁,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,629評論 2 354