var adder = {
base : 1,
add : function(a) {
console.log(this)
var f = v => v + this.base;
return f(a);
},
addThruCall: function(a) {
var f = v => v + this.base;
var b = {
base : 2
};
return f.call(b, a);
}
};
var obj = {
i: 10,
b: () => console.log(this.i, this),
c: function() {
return ()=>{
console.log( this.i, this)
}
}
}
obj.b();
obj.c()();
块语句(也就是{} 包括的语句)中用到的var变量,不会创建新的作用域,因此变量会提升。
在for循环中,let和var的区别,我想是因为循环的时候,每次使用let关键字,都会创建一个新的作用域,这也是
把let 称作块级作用域的变量
而var 并不会在在if,for,while,switch 等函数里面创建新的作用域,因此变量会提升,导致输出的结

本文探讨JavaScript中的this指向问题,包括箭头函数、作用域(var与let的区别)、执行上下文等概念。通过实例解析函数内部this的确定规则,并分析不同场景下this的变化。同时,介绍了块级作用域和变量提升的概念,帮助理解JavaScript中的作用域规则。
最低0.47元/天 解锁文章
764

被折叠的 条评论
为什么被折叠?



