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

非严格模式下,






