javascript 逗号操作符

return (a,b) //引发的思考
//返回值为 b

我当时就懵逼了,这是什么鬼?为什么还有这种操作?

demo是这样的:
let json = {
    a:{
        x: 12,
        y: 13
       },
     b:{
          x: 1,
          y: 3
       }
}
//我需要把数据转化为
let arr = [
      {
          name:a,
          x:12,
          y:13
      },
      {
         name:b,
          x:1,
          y:3
      }
]

//然后就看到了一个骚操作
Object.keys(json).reduce((result,item)=>{
        return (result.push({
              name:item,
              ...json[item]
        }),result)
},[])

//说实话我当时就懵逼了

详细剖析一下我的懵逼点
return (result.push({
              name:item,
              ...json[item]
        }),result)

带括号干嘛?直接return result.push()不就ok了吗,事实证明不ok。
原因 arr.push()是有返回值的,返回数组的长度。直接返回会导致报
错,长度.push() 必须报错。
再不济我可以写成

result.push(item)
return result

这个没毛病也可以看懂。
接下来开始搜索相关问题,由于我的无知甚至搜索了reduce的相关文章和push的文章,一无所获。

后来突然想到会不会和“,”有关

然后就搜到了MDN的逗号操作符,尼玛第一句就是:

逗号操作符 对它的每个操作数求值(从左到右),并返回最后一个操作数的值。
function myFunc () {
  var x = 0;

  return (x += 1, x); // the same of return ++x;
}

呵呵 到此问题是得到了完美解释。

结论就是多读点书!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 故事是这样的..一个哥们在面试给我发了道题..我一下就懵圈了.. 当时的内心os是,为什么for的条件可以有两个,...
    寻猫的耗子阅读 2,726评论 0 0
  • 最近看了些其他人分享的面试经历 发现了这么一道题 突然就陷入了沉思,这好像触及到了我的知识盲区... 一开始以为这...
    给我一只小熊猫阅读 5,105评论 0 0
  • 相关链接mdn - Comma_Operatorstackoverflow - Why does babel re...
    holidayPenguin阅读 8,192评论 3 4
  • 1. 逗号操作符 逗号操作符(,)可以构成逗号表达式:逗号表达式用于将多个表达式连接为一个表达式逗号表达式的值为最...
    编程半岛阅读 1,850评论 0 0
  • 使用逗号操作符可以再一条语句中执行多个操作,如下面的例子所示: 逗号操作符多用于申明多个变量;但除此之外,逗号操作...
    meiqiuyang阅读 2,548评论 0 0

友情链接更多精彩内容