Why operator inside parenthesis changes `this` in function call(为什么圆括号内的运算符在函数调用中更改为`this`)
本文介绍了为什么圆括号内的运算符在函数调用中更改为`this`的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
谈话很便宜;请给我看代码。
// equals to this.test = "inside window"
var test = "inside window";
function f () {
console.log(this.test)
};
var obj = {
test: "inside object",
fn: f
};
obj.fn(); // "inside object" --> fine
(obj).fn(); // "inside object" --> fine
(1, obj).fn(); // "inside object" --> fine
(obj.fn)(); // "inside object" --> fine
(0 || obj.fn)(); // "inside window" --> why?
// reference equality check
console.log(
f === obj.fn &&
(obj.fn) === f &&
f === (1, obj.fn)
); // all equal :/
()
和comma operator
,正如您在最后一条语句中看到的那样,comma operator
做了一些奇怪的事情。我怀疑它在返回值时执行赋值(因为如果我们执行赋值也会产生相同的结果),但我不确定。
更新:
&&
、||
运算符:(0 || obj.fn)()
推荐答案
给定:
foo.bar()
内部bar
,this
将为foo
。
(有例外,例如bar
是用箭头函数定义的,但在这种情况下不适用)。
给定:
const bar = foo.bar;
bar();
现在已在没有foo
上下文的情况下调用了函数,因此this
现在是默认对象(在浏览器中为window
)。
表达式:(1, foo.bar)
计算为右侧。这就是函数。
就像您已将其复制到变量一样,这会在您调用函数之前断开它与对象的连接,因此您将获得相同的效果。
没有赋值,因为您没有涉及变量,但您调用的是表达式的结果,而不是直接调用对象方法。
这篇关于为什么圆括号内的运算符在函数调用中更改为`this`的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:为什么圆括号内的运算符在函数调用中更改为`this`


基础教程推荐
猜你喜欢
- 当用户滚动离开时如何暂停 youtube 嵌入 2022-01-01
- 角度Apollo设置WatchQuery结果为可用变量 2022-01-01
- 悬停时滑动输入并停留几秒钟 2022-01-01
- 在 JS 中获取客户端时区(不是 GMT 偏移量) 2022-01-01
- Karma-Jasmine:如何正确监视 Modal? 2022-01-01
- 动态更新多个选择框 2022-01-01
- 我什么时候应该在导入时使用方括号 2022-01-01
- 在for循环中使用setTimeout 2022-01-01
- 响应更改 div 大小保持纵横比 2022-01-01
- 有没有办法使用OpenLayers更改OpenStreetMap中某些要素 2022-09-06