您好,登錄后才能下訂單哦!
這篇文章主要介紹“Javascript怎么實現json合并的場景”,在日常操作中,相信很多人在Javascript怎么實現json合并的場景問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Javascript怎么實現json合并的場景”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
2個json合并,
jQuery 的“extend()”方法有兩個原型:合并的方法,分別是淺合并和深度合并,其實淺合并只是json的第一層被合并,而深度合并是全部層數都被合并,分別如下寫法:
1.淺合并,target被object1...合并,只有一層
$.extend( target [, object1 ] [, objectN ] )
深度合并,target被object1...合并,包含一層二層三層...
要深度合并, [deep]需要為true, 后面覆蓋前面,所以如要要保留后面的,則需要 object1 =$.extend(true,target,object1) ,但target已經變化了
$.extend( [deep ], target, object1 [, objectN ] )
這是jquery自帶的,下面帶大家看看javascript如何實現。
/** * 遇到相同元素級屬性,以(minor)為準 // 不返還新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)為準為主, //console.log(key) if(isJSON(minor[key])||isArray(minor[key])) { // arguments.callee 遞歸調用,并且與函數名解耦 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]'; }
測試
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);
到此,關于“Javascript怎么實現json合并的場景”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。