var length = 10;
function fn() {
console.log(this.length);
}
var obj = {
method: function(fn) {
fn();
arguments[0]();
}
};
obj.method(fn, 1);
第一个输出10,因为fn声明时的上下文是window,所以打印全局变量10,第二个输出2为什么了,有确切的分析吗,这时候fn的上下文怎么变成arguments的上下文的?
var length = 10;
function fn() {
console.log(this.length);
}
var obj = {
method: function(fn) {
fn();
arguments[0]();
}
};
obj.method(fn, 1);
第一个输出10,因为fn声明时的上下文是window,所以打印全局变量10,第二个输出2为什么了,有确切的分析吗,这时候fn的上下文怎么变成arguments的上下文的?
13 回答13k 阅读
7 回答2.1k 阅读
3 回答1.3k 阅读✓ 已解决
6 回答1.2k 阅读✓ 已解决
2 回答1.4k 阅读✓ 已解决
3 回答1.3k 阅读✓ 已解决
6 回答1.1k 阅读
属性运算符有两种 . 和 []
obj.fn() === obj['fn']()
使用运算符调用属性的时候,自动绑定this
这就是为什么 arguments变为this的原因。