我想知道是否,以及如果下面的工作如何工作:
我有一个如下定义的数组:
- 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;
- },{}))
- }