一个有趣的Js逗号表达式

3,045 阅读1分钟

一些框架源码中经常看到类似这样的语法:

(0, xx.default)(param1, param2)

乍一看是个方法调用,但是为何要如此写法?

大家应该都知道运算符优先级圆括号最高,逗号最低,

逗号运算从左到右运算,返回最右边的值,

来看一个小例子:

// 函数调用,函数内部的this为空(严格模式下) 
func(param);
// 方法调用,方法内部的this为obj
obj.method(param)

所以下面的函数内中this指向了xx

xx.default(param1, param2)

(0, xx.default)(param1, param2)
// 等价于:
const func = xx.default;
// 此时,this指向window/global
func(param1, param2)

大家可以打开控制台试一下:

哈哈,也是挺有趣的^_^