箭头函数的this在定义时从外层第一个普通函数继承,运行时不可变;call/apply/bind对其无效;对象字面量中直接定义会导致this指向全局或undefined,而非对象本身。
箭头函数的 this 不是运行时决定的,它根本就没有自己的 this 绑定过程;它只是在定义那一刻,从词法环境里“拿走”外层第一个普通函数的 this 值,之后永远不变。
普通函数的 this 看“谁调用”,而箭头函数的 this 看“在哪写”。只要找到它直接嵌套的最近一层非箭头函数,那个函数执行时的 this 就是答案。
obj.method = function() { const f = () => console.log(this); }),this 就是该方法被调用时的对象const f = () => console.log(this);),this 是全局对象(浏览器中为 window)或 undefined(严格模式)handler = () => console.log(this)),那它捕获的是类构造时的上下文,即实例本身——但这是因构造函数执行时定义了它,不是因为 class 语法特殊这些方法本意是强行指定函数运行时的 this,但箭头函数压根不参与运行时绑定流程,传进去的 thisArg 会被忽略。
arrowFunc.call(obj, 1, 2) → this 仍是定义时捕获的那个值,obj 被丢弃obj.f = arrowFunc; obj.f(),this 也不会变成 obj
最容易出错的地方,是把箭头函数当普通方法写在对象字面量里,误以为 obj.f() 中的 this 会指向 obj。
立即学习“Java免费学习笔记(深入)”;
const obj = { name: 'A', f: () => console.log(this.name) }; → this 是全局或 undefined,不是 obj
setTimeout 外层函数(比如组件方法)执行时的 this
function 或方法体,它的 this 就是答案下面两段代码行为完全不同:
普通函数:const regular = function() { console.log(this.x); };
调用时 regular.call({x: 100}) 输出 100,regular() 输出 undefined(严格模式)
箭头函数:const arrow = () => console.log(this.x);
无论怎么调用,输出都取决于它定义时外层函数的 this —— 它不响应任何调用方式的变化