this 是 JavaScript 中动态绑定的关键字,其值取决于函数调用方式:普通调用时非严格模式指向全局对象、严格模式为 undefined;对象方法调用时指向该对象;call/apply/bind 可显式绑定;箭头函数无自有 this,继承外层词法作用域的 this。
this 是 JavaScript 中一个特殊的关键字,它不是一个固定值,而是在函数被调用时才动态确定的,指向**当前执行上下文中的对象**。它的具体指向不取决于函数如何定义,而取决于函数**如何被调用**。
直接调用函数(如 foo()),没有点号或绑定:
this 指向全局对象(浏览器中是 window,Node.js 中是 global)this 是 undefined
当函数作为对象的属性被调用(即通过点号或方括号访问后加括号),this 指向**该对象本身**:
obj.method() → this 指向 obj
obj['method']() → 同样指向 obj
const fn = obj.method;),再调用 fn() 就变成普通调用,this 不再是 obj
可以通过这三个内置方法强制指定函数运行时的 this 值:
func.call(obj, arg1, arg2) —— 立即执行,参数逐个传入func.apply(obj, [arg1, arg2]) —— 立即执行,参数以数组形式传入const bound = func.bind(obj) —— 返回一个新函数,永久绑定 this 为 obj
箭头函数不创建自己的执行上下文,它会**继承外层普通函数作用域中的 this**(词法绑定):
this 不指向该对象,而是指向定义时所在上下文的 this
this 失去绑定(比如事件处理、定时器、Promise 链)call/apply/bind 改变箭头函数的 this