2016-10-17 11:28发布
var foo = { bar:function(){ console.log(this); } } foo.bar(); (foo.bar)(); (foo.bar = foo.bar)();//window (foo.bar,foo.bar)();//window (false || foo.bar)();//window
谁帮忙解释下后三个为什么呀???
此时foo.bar作为变量,还没有作为语句被计算过,还未丢失foo,调用的时候等同foo.bar().
所以很多时候我们都是
原因是没有直接使用 foo 做为context
简单来讲后三个函数调用左边不是内部引用类型,所以函数调用确定的 this 是 undefined,在非严格模式下内部会设置为 全局对象。具体看这篇博客 https://m2mbob.cn/2016/09/25/...
同上
这问题很有意思!
同上,作为语句被执行
foo.bar = foo.bar是一个语句,调用时执行该语句返回一个function,已丢失foo,又因为全局调用,所以this被赋值为当前全局对象。
最多设置5个标签!
付费偷看金额在0.1-10元之间
此时foo.bar作为变量,还没有作为语句被计算过,还未丢失foo,调用的时候等同foo.bar().
所以很多时候我们都是
原因是没有直接使用 foo 做为context
简单来讲后三个函数调用左边不是内部引用类型,所以函数调用确定的 this 是 undefined,在非严格模式下内部会设置为 全局对象。具体看这篇博客 https://m2mbob.cn/2016/09/25/...
同上
这问题很有意思!
同上,作为语句被执行
foo.bar = foo.bar是一个语句,调用时执行该语句返回一个function,已丢失foo,又因为全局调用,所以this被赋值为当前全局对象。
一周热门 更多>