一个有趣的Js逗号表达式

逗号运算与this指向

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

(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)
复制代码

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

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

转载于:https://juejin.im/post/5cbf2639f265da03ac0d0c6c

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值