仅当值不为null时才推送Javascript数组

我想知道是否,以及如果下面的工作如何工作:

我有一个如下定义的数组:

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;
    },{}))
}

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...