贝利信息

javascript this关键字如何绑定_哪些规则决定了它的值?

日期:2026-01-02 00:00 / 作者:狼影
普通函数直接调用时,非严格模式下this指向全局对象(如window),严格模式下为undefined;箭头函数无this,继承外层作用域;call/apply/bind可手动指定this,bind返回的新函数this不可再被call/apply更改;对象方法赋值后调用会丢失this绑定;new调用时this指向新创建的实例。

普通函数调用时 this 指向什么

直接调用 fn(),非严格模式下 this 指向全局对象(浏览器中是 window),严格模式下是 undefined。这是最容易出错的场景——你以为在对象方法里写了个函数,结果忘了绑定,this 就飞了。

call / apply / bind 如何强行指定 this

这三个方法本质都是手动传入第一个参数作为函数执行时的 this 值,区别只在参数传递方式:call 用逗号分隔,apply 用数组,bind 返回新函数且可预设部分参数。

function greet(greeting, punctuation) {
  return `${greeting}, ${this.name}${punctuation}`;
}
const person = { name: 'Alice' };

greet.call(person, 'Hello', '!');     // "Hello, Alice!"
greet.apply(person, ['Hi', '?']);     // "Hi, Alice?"
const hiAlice = greet.bind(person, 'Hi');
hiAlice('!');                         // "Hi, Alice!"

对象方法中的 this 为什么有时失效

当把对象方法赋值给变量或作为回调传入时,this 会丢失绑定,变成默认绑定规则(上一条)。常见于事件监听、定时器、Promise 回调等场景。

new 调用时 this 怎么确定

new 调用函数时,引擎会创建一个新对象,把 this 绑定到该对象,并让其原型指向构造函数的 prototype。此时无论函数内部怎么写 this,都指向这个新实例。

function Person(name) {
  this.name = name;        // 这里的 this 就是 new 出来的实例
  this.say = function() {
    return `I'm ${this.name}`; // this 依然指向实例
  };
}
const p = new Person('Bob');
p.say(); // "I'm Bob"
实际写代码时,最常踩的坑不是记不住规则,而是混淆「定义时的作用域」和「调用时的绑定」。尤其是把方法传给第三方库(比如 React 的 onClick、Lodash 的 debounce)时,得时刻问一句:这个函数被谁调用?this 是谁?