Javascript實(shí)用方法之json合并的場(chǎng)景分析
場(chǎng)景
2個(gè)json合并,
jQuery 的“extend()”方法有兩個(gè)原型:合并的方法,分別是淺合并和深度合并,其實(shí)淺合并只是json的第一層被合并,而深度合并是全部層數(shù)都被合并,分別如下寫法:
1.淺合并,target被object1...合并,只有一層
$.extend( target [, object1 ] [, objectN ] )
深度合并,target被object1...合并,包含一層二層三層...
要深度合并, [deep]需要為true, 后面覆蓋前面,所以如要要保留后面的,則需要 object1 =$.extend(true,target,object1) ,但target已經(jīng)變化了
$.extend( [deep ], target, object1 [, objectN ] )
這是jquery自帶的,下面帶大家看看javascript如何實(shí)現(xiàn)。
代碼
1.深度合并(遞歸)
/**
* 遇到相同元素級(jí)屬性,以(minor)為準(zhǔn) // 不返還新Object,而是main改變
* mirror
* main
*/
function mergeJSON(minor, main) {
for(var key in minor) {
if(main[key] === undefined) { // 不沖突的,直接賦值
main[key] = minor[key];
continue;
}
// 沖突了,如果是Object,看看有么有不沖突的屬性
// 不是Object 則以(minor)為準(zhǔn)為主,
//console.log(key)
if(isJSON(minor[key])||isArray(minor[key])) { // arguments.callee 遞歸調(diào)用,并且與函數(shù)名解耦
console.log("is json")
//arguments.callee(minor[key], main[key]);
mergeJSON(minor[key], main[key]);
}else{
main[key] = minor[key];
}
}
}
//判斷是否是json
function isJSON(target) {
return typeof target == "object" && target.constructor == Object;
}
//判斷是否是array
function isArray(o) {
return Object.prototype.toString.call(o) == '[object Array]';
}測(cè)試
var a = {
ccc: {
d: 111,
b: 222,
a: 222,
ee: [{
a: 1
}, {
b: 2
}]
}
};
var b = {
ccc: {
fff: 666,
ee: [{
c: 3
}]
}
};
mergeJSON(b, a);
console.log(a);
console.log(b);到此這篇關(guān)于Javascript實(shí)用方法之json合并的文章就介紹到這了,更多相關(guān)js json合并內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript中的相等操作符(==與===區(qū)別)
這篇文章主要介紹了javascript中的相等操作符(==與===區(qū)別),需要的朋友可以參考下2019-12-12
前端使用URL API實(shí)現(xiàn)高效的URL解析
在現(xiàn)代Web開發(fā)中,URL是前端和后端交互的核心載體,本文將深入探討如何利用URL API實(shí)現(xiàn)URL的解析,構(gòu)建和操作,希望對(duì)大家有一定的幫助2025-04-04
JavaScript制作頁(yè)面倒計(jì)時(shí)器的實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了JavaScript制作頁(yè)面倒計(jì)時(shí)器的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-03-03
JavaScript 保存數(shù)組到Cookie的代碼
大部分的瀏覽器一個(gè)網(wǎng)站只支持保存20個(gè)Cookie,超過(guò)20個(gè)Cookie,舊的Cookie會(huì)被最新的Cookie代替。那么如果要有超過(guò)20個(gè)Cookie要保存只能將Cookie存為數(shù)組然后保存到Cookie。2010-04-04

