我想知道是否,以及如果下面的工作如何工作:
我有一个如下定义的数组:
var array = [
{number: '1',value: 'one',context: 'someContext'},{number: '2',value: 'two',context: 'anotherContext'},...
]
我目前正在做的是将元素推入数组,所以array.push({number:’1′,value:’one’,context:’someContext’});等等,每个数组元素.
现在这个东西被扩展了:说还有另一个叫做“内容”的键.此键具有适当的值,可以是undefined或字符串.现在的问题是:如果我把推送放在这样的函数中:
push(number,value,context,content) {
array.push({
number: number,value: value,context: context,content: content
})
}
无论如何,我可以确保,如果内容(函数作为参数获取)不为null,则关键内容仅添加到元素中.
当然我可以修改这样的功能:
push(number,content) {
if(!content) {
array.push({
number: number,content: content
})
} else {
array.push({
number: number,context: context
})
}
}
但问题是,如果在推送功能中无论如何都要这样做.我也想过类似的东西
array.push({
number: number,content? content: content
})
因此,只有在定义了内容时才会插入它,但这样做有效,看起来不像,但可能是我的代码中的错误.
解决方法
如果对象不仅仅是使代码更短,那么最可读的就是这样,你可以在其中创建对象,如果有值则添加属性,然后将对象推送到数组.
push(number,content) {
var o = {
number : number,value : value,context : context
}
if (content !== null) o.content = content;
array.push(o);
);
这是一种在Array.push中直接构造对象的ES6方法,并过滤任何以null为值的对象.
function push(...arg) {
array.push(['number','value','context','content'].reduce((a,b,i)=> {
if (arg[i] !== null) a[b]=arg[i]; return a;
},{}))
}