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 concrete
和 baseline
,我希望输出是这样的:
{
"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,但它似乎没有将同名的值相互合并。
我尝试使用 concat
和 Object.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
Lodash 和 Underscore 是高级 javascript 对象操作的最佳库。
查看这两个问题,详细了解您可以做什么:
Lodash - difference between .extend() / .assign() and .merge()
Lodash: Constructing single object from many - Merging/overriding properties
我正在使用 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 concrete
和 baseline
,我希望输出是这样的:
{
"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,但它似乎没有将同名的值相互合并。
我尝试使用 concat
和 Object.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
Lodash 和 Underscore 是高级 javascript 对象操作的最佳库。
查看这两个问题,详细了解您可以做什么:
Lodash - difference between .extend() / .assign() and .merge()
Lodash: Constructing single object from many - Merging/overriding properties