登录
首页 >  文章 >  前端

JavaScript中this的指向解析

时间:2026-04-20 17:54:42 322浏览 收藏

JavaScript 中的 this 并非由函数定义位置决定,而是在每次执行时动态绑定,完全取决于函数“如何被调用”:普通调用指向全局对象或 undefined,对象方法调用指向调用者对象,构造调用指向新实例,显式绑定(call/apply/bind)则强制指定 this;箭头函数更特殊——它没有自己的 this,而是继承外层作用域的绑定。真正让人困惑的不是规则本身,而是那些看似自然却悄然丢失 this 的场景:方法赋值后独立调用、事件回调、定时器或高阶函数传参……掌握“谁在调用这个函数”这一核心思维,才能彻底摆脱 this 的意外陷阱。

javascript this是什么_它的值在什么情况下会改变?

JavaScript 中 this 指向谁,完全取决于「函数怎么被调用」

this 不是定义时决定的,也不是由函数本身决定的。它在每次函数执行时才绑定,绑定规则只看调用位置和方式。常见误解是认为 this 指向函数所在对象,但其实只要函数被“脱离上下文”调用,this 就会变。

四种主要调用方式决定 this

记住这四类,覆盖 95% 的实际场景:

  • 普通函数调用fn() → 非严格模式下 thiswindow(浏览器)或 globalThis(Node),严格模式下是 undefined
  • 对象方法调用obj.method()thisobj(前提是没被赋值或解构)
  • 构造函数调用new Fn()this 是新创建的实例对象
  • 显式绑定fn.call(obj, ...)fn.apply(obj, [...])fn.bind(obj)this 强制为传入的 obj

容易踩坑的三种典型场景

这些地方 this 最常“意外丢失”:

  • 对象方法赋值给变量后调用
    const obj = { name: 'a', say() { console.log(this.name) } };
    const fn = obj.say;
    fn(); // this 是 undefined(严格模式),输出 undefined —— 不是 'a'
  • 回调函数中直接使用对象方法
    button.addEventListener('click', obj.say); // 点击时 this 指向 button,不是 obj
    解决:用 obj.say.bind(obj)() => obj.say()obj.say.bind(obj)
  • 箭头函数没有自己的 this:它会沿作用域链向上找外层函数的 this,且无法被 call/apply/bind 改变

ES6 类方法里的 this 为什么有时也出问题?

类中的方法默认不自动绑定 this,尤其在作为事件处理器、定时器回调、或传入高阶函数(如 mapsetTimeout)时,本质还是上面的「赋值后调用」问题:

  • class C { handleClick() { console.log(this) } }; const c = new C(); setTimeout(c.handleClick, 100)thisundefined(严格模式)
  • 修复方式:在 constructor 中绑定 this.handleClick = this.handleClick.bind(this),或用箭头属性 handleClick = () => { ... },或调用时写成 setTimeout(() => c.handleClick(), 100)

真正麻烦的不是规则多,而是你得时刻问自己一句:“这个函数此刻是被谁调用的?”——而不是“它写在哪儿”。

今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>