美文网首页
逗号操作符(0,function)()

逗号操作符(0,function)()

作者: ouxuwen | 来源:发表于2019-07-09 15:49 被阅读0次

无聊之际看了一下antd的源码,发现一段代码如下:

var ButtonTypes = (0, _type.tuple)('default', 'primary', 'ghost', 'dashed', 'danger', 'link');
var ButtonShapes = (0, _type.tuple)('circle', 'circle-outline', 'round');
var ButtonSizes = (0, _type.tuple)('large', 'default', 'small');
var ButtonHTMLTypes = (0, _type.tuple)('submit', 'button', 'reset');
// tuple 实际上就是一个返回参数数组的函数
var tuple = function tuple() {
    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
      args[_key] = arguments[_key];
    }
    return args;
  };

发现了 (0,function) 这个写法好像好像没见过,于是就研究了一下:
相关链接:https://developer.mozilla.org...

逗号操作符

概述:逗号操作符对它的每个操作数求值(从左到右),并返回最后一个操作数的值。当你想要在期望一个表达式的位置包含多个表达式时,可以使用逗号操作符。这个操作符最常用的一种情况是:for 循环中提供多个参数。需要注意的是,var 语句中的逗号不是逗号操作符,因为它不是存在于一个表达式中。

案例:

function testFunc () {
  var a = 0;
  return (a += 1, a); // 等价于return ++x;
}

console.log((1, 2)); // console 2
console.log((a = b = 3, c = 4)); // console 4

逗号操作符的用处

先看一个案例:

var obj = {
    myFunc: function () {
        console.log(this === window);
        console.log(this === obj);
    }
}
obj.myFunc();   // false  true
(0,obj.myFunc)(); // true false

输出的结果为 :
false
true
ture
false。

解释:

在函数foo中,this指向的是obj,因为foo是obj的方法。所以this===window返回false就能理解了。
但是调用(0,obj.myFunc)(),表达式(0,obj.foo)将评估它的每个操作数(从左到右),并返回最后一个操作数的值。换句话说,(0,obj.foo)等于返回一个函数:

ƒ () {
        console.log(this === window);// this是全局对象window,所以输出的是true。
        console.log(this === obj);// this是全局对象window,所以输出的是false。
    }

相关文章

  • 逗号操作符 & (0, function)()

    相关链接mdn - Comma_Operatorstackoverflow - Why does babel re...

  • 逗号操作符(0,function)()

    无聊之际看了一下antd的源码,发现一段代码如下: 发现了 (0,function) 这个写法好像好像没见过,于...

  • JavaScript 逗号表达式笔记

    #JavaScript 逗号表达式笔记 ##逗号操作符是多元操作符,可以在一条语句中执行多个操作 1.逗号操作符可...

  • 逗号操作符

    基本概念: 使用逗号操作符可以在一条语句中执行多个操作。逗号操作符多用于声明多个变量;但除此之外,逗号操作符还可以...

  • Java之逗号操作符

    在说逗号操作符的时候我们要注意,逗号操作符不是逗号分隔符,逗号用作分隔符时用来分隔函数的不同参数。 Java里唯一...

  • 3.5.10 逗号操作符

    使用逗号操作符可以再一条语句中执行多个操作,如下面的例子所示: 逗号操作符多用于申明多个变量;但除此之外,逗号操作...

  • JS 中强大的操作符

    1.0 数值操作符_ 2.0 逗号运算符 , 3.0零合并操作符 ?? (||) 4.0可选链操作符?. (&&...

  • JavaScript基本概念之操作符——逗号操作符

    逗号操作符 使用都会操作符可以在一条语句中执行多个操作。

  • (0,fn) 逗号运算符

    源码中的(0,fn)() 逗号操作符 :对它的每个操作数求值(从左到右),并返回最后一个操作数的值 可以看到,...

  • 五 typeof &类型转化

    typeof操作符 number string boolean object undefined function...

网友评论

      本文标题:逗号操作符(0,function)()

      本文链接:https://www.haomeiwen.com/subject/jfxpqctx.html