Javascript 对象文字模板:使用基线扩展实现对象

Javascript object literal template: Extending implementation object with a baseline

我正在使用 javascript 对象字面量,并且得到了一个绝妙的想法,即通过抽象所有公共属性来简化我必须使用的实际对象字面量。

因此,我想 extend/inherit/merge 我的具体对象来自基线预定义对象结构。 我的意思是这样的:

基线:

{  
       "id":"",
       "options":[  
          {  
             "1":true,
              "concreteValue":"important"
          },
          {  
             "2":false,
              "concreteValue":"unimportant"
          },
          {  
             "3":true,
             "concreteValue":"important"
          }
       ],
       "greeting":"Howdy",
       "player":{  
          "name":"",
          "hp":1,
          "mana":10
       }
}

具体:

{  
   "id":"player1",
   "options":[  
      {  
         "5":true,
          "concreteValue":"awesome"
      }
   ],
   "greeting":"Greetings!",
   "player":{  
      "name":"player1",
      "hp":15
   }
}

并通过 extending/inheriting/merging concretebaseline,我希望输出是这样的:

{  
   "id":"player1",
   "options":[  
      {  
         "1":true,
         "concreteValue":"important"
      },
      {  
         "2":false,
         "concreteValue":"unimportant"
      },
      {  
         "3":true,
         "concreteValue":"important"
      },
      {  
         "5":true,
         "concreteValue":"awesome"
      }
   ],
   "greeting":"Greetings!",
   "player":{  
      "name":"player1",
      "hp":15,
      "mana":10
   }
}

因此,两个地方都存在的值将被混凝土中的值覆盖,添加尚不存在的值。 这似乎是一种很好的做事方式,所以我确信有一种聪明的方法可以做到这一点,但我还没有找到 :) 我查看了 jQuery Extend,但它似乎没有将同名的值相互合并。

我尝试使用 concatObject.Assign,但它们也没有成功。 有人有什么想法吗?

为此,您可以像下面这样更改 options 对象的结构,然后 jQuery.extend(true, baseline, concrete) 就可以了

"options": {
    "5": {
      "someName": true,
      "concreteValue": "important"
    }
  },

See this jsFiddle 产生这个结果:

Lodash 库可以在这里使用。

我可能会选择@DelightedD0D 解决方案而不是添加额外的库,如果这是你唯一使用 Lodash 的东西。

使用 Lodash 的优势在于 customizer 函数,您可以在其中指定一些自定义合并好东西,尽管我不知道在 jQueryextend方法.

您可以使用 merge(src, dest, customizer) 函数来获取您所描述的内容,结果如下:
http://jsbin.com/qibeji/edit?js,console

LodashUnderscore 是高级 javascript 对象操作的最佳库。

查看这两个问题,详细了解您可以做什么:
Lodash - difference between .extend() / .assign() and .merge()
Lodash: Constructing single object from many - Merging/overriding properties