国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

JavaScript實現JSON合并操作示例【遞歸深度合并】

2024-05-06 16:46:00
字體:
來源:轉載
供稿:網友

本文實例講述了JavaScript實現JSON合并操作。分享給大家供大家參考,具體如下:

為什么我會想到寫這幾行代碼

在實際工作中,我們會使用許多或自主開發或第三方的工具,有些工具的配置文件相當細節,使用頻率低倒也罷了,使用頻率高的話必然造成很多代碼冗余。所以我都會對這些工具做二次封裝,把不經常改動的配置給予默認值。如果需要改動,傳入新的配置覆蓋原來的配置即可。

起初我以為這是一項很簡單的需求

var json1 = {  // 固定的配置 a: 1, b: 2, c: 3,}var json2 = {  // 作為參數傳入的配置 a: 11, d: 14,}json3 = {  // 合并后的結果 a: 11, b: 2, c: 3, d: 14,}

如上述,確實很簡單。可事實是,當配置不再是僅僅一層嵌套時,常用的合并如$.extendfor in 賦值就不再能再解決問題了

var json1 = { a: 1, b: {  b1: 'hello',  b2: 'world', },}var json2 = { b: { b2: 'china' }, c: 3,}json3 = {  // 合并后的結果 a: 1, b: { b2: 'chila' }, c: 3,}

可以看出,我們的本意是希望json2里的b.b2: 'china'取代json1里的b.b2: 'world', 可是實際上,常規的結果只會把整個object/json取代,而不會去遍歷其中的屬性,在本例中導致了b.b1的丟失。

于是就有了如下幾行代碼:

// 遇到相同元素級屬性,以后者(main)為準// 不返還新Object,而是main改變function mergeJSON (minor, main) { for (var key in minor) {  if (main[key] === undefined) { // 不沖突的,直接賦值   main[key] = minor[key];   continue;  }  // 沖突了,如果是Object,看看有么有不沖突的屬性  // 不是Object 則以main為主,忽略即可。故不需要else  if (isJSON(minor[key])) {   // arguments.callee 遞歸調用,并且與函數名解耦   arguments.callee(minor[key], main[key]);  } }}// 附上工具function isJSON(target) { return typeof target == "object" && target.constructor == Object;}

雖然只有十幾行的代碼,但還是挺實用。粗略的挖掘了一下搜索引擎,好像并沒有更合適解決問題的代碼。簡單的遞歸思想和argument.callee琢磨一下也是有些味道的

希望本文所述對大家JavaScript程序設計有所幫助。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 库伦旗| 江北区| 麦盖提县| 阿勒泰市| 安化县| 大同县| 辽中县| 千阳县| 黄骅市| 遵义市| 壶关县| 绥芬河市| 常德市| 邛崃市| 漳平市| 余江县| 海兴县| 庆元县| 敦化市| 大名县| 隆安县| 两当县| 延津县| 黄龙县| 天门市| 瑞丽市| 梨树县| 临颍县| 大姚县| 遂宁市| 华阴市| 安仁县| 准格尔旗| 四川省| 黄浦区| 西宁市| 庄河市| 普兰店市| 阳西县| 鹤峰县| 平阳县|