Javascript的this关键字是什么_它的指向如何确定?

this 是 JavaScript 中动态绑定的关键字,其值取决于函数调用方式:普通调用时非严格模式指向全局对象、严格模式为 undefined;对象方法调用时指向该对象;call/apply/bind 可显式绑定;箭头函数无自有 this,继承外层词法作用域的 this。

this 是 JavaScript 中一个特殊的关键字,它不是一个固定值,而是在函数被调用时才动态确定的,指向**当前执行上下文中的对象**。它的具体指向不取决于函数如何定义,而取决于函数**如何被调用**。

普通函数调用时的 this(非严格模式 vs 严格模式)

直接调用函数(如 foo()),没有点号或绑定:

  • 非严格模式下,this 指向全局对象(浏览器中是 window,Node.js 中是 global
  • 严格模式下,thisundefined

对象方法调用时的 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) —— 返回一个新函数,永久绑定 thisobj

箭头函数没有自己的 this

箭头函数不创建自己的执行上下文,它会**继承外层普通函数作用域中的 this**(词法绑定):

  • 在对象方法中写箭头函数,this 不指向该对象,而是指向定义时所在上下文的 this
  • 常用于避免回调中 this 失去绑定(比如事件处理、定时器、Promise 链)
  • 不能用 call/apply/bind 改变箭头函数的 this