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

前端之家收集整理的这篇文章主要介绍了仅当值不为null时才推送Javascript数组前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想知道是否,以及如果下面的工作如何工作:

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

  1. var array = [
  2. {number: '1',value: 'one',context: 'someContext'},{number: '2',value: 'two',context: 'anotherContext'},...
  3. ]

我目前正在做的是将元素推入数组,所以array.push({number:’1′,value:’one’,context:’someContext’});等等,每个数组元素.

现在这个东西被扩展了:说还有另一个叫做“内容”的键.此键具有适当的值,可以是undefined或字符串.现在的问题是:如果我把推送放在这样的函数中:

  1. push(number,value,context,content) {
  2. array.push({
  3. number: number,value: value,context: context,content: content
  4. })
  5. }

无论如何,我可以确保,如果内容(函数作为参数获取)不为null,则关键内容添加到元素中.

当然我可以修改这样的功能

  1. push(number,content) {
  2. if(!content) {
  3. array.push({
  4. number: number,content: content
  5. })
  6. } else {
  7. array.push({
  8. number: number,context: context
  9. })
  10. }
  11. }

但问题是,如果在推送功能中无论如何都要这样做.我也想过类似的东西

  1. array.push({
  2. number: number,content? content: content
  3. })

因此,只有在定义了内容时才会插入它,但这样做有效,看起来不像,但可能是我的代码中的错误.

解决方法

如果对象不仅仅是使代码更短,那么最可读的就是这样,你可以在其中创建对象,如果有值则添加属性,然后将对象推送到数组.
  1. push(number,content) {
  2.  
  3. var o = {
  4. number : number,value : value,context : context
  5. }
  6.  
  7. if (content !== null) o.content = content;
  8.  
  9. array.push(o);
  10. );

这是一种在Array.push中直接构造对象的ES6方法,并过滤任何以null为值的对象.

  1. function push(...arg) {
  2. array.push(['number','value','context','content'].reduce((a,b,i)=> {
  3. if (arg[i] !== null) a[b]=arg[i]; return a;
  4. },{}))
  5. }

猜你在找的JavaScript相关文章