登录
首页 >  文章 >  前端

JavaScript中this的正确使用方法解析

时间:2026-03-03 10:33:59 213浏览 收藏

JavaScript中的this并非指向函数自身或定义时的作用域,而是完全由函数**如何被调用**动态决定的执行上下文对象——它在严格模式下独立调用会返回undefined,箭头函数则彻底摒弃自身this、无条件继承外层作用域;call/apply/bind虽能显式操控this,但bind的绑定不可逆,而new调用又会将其重置为新实例(除非函数返回对象);更易踩坑的是事件监听中,this看似指向触发元素,却极易因箭头函数、函数解构或异步操作悄然丢失。掌握this的本质,就是理解“调用方式即上下文”,而非死记规则——这正是避开无数隐蔽bug、写出健壮可维护代码的关键起点。

怎样理解JavaScript中的this关键字【教程】

JavaScript 中的 this 不是指“函数自己”或“定义时的作用域”,而是**函数被调用时的执行上下文对象**——它完全取决于函数怎么被调用,而不是怎么被声明。

为什么 this 在普通函数里经常是 undefined(严格模式)?

在严格模式下,全局环境中直接调用函数(如 foo()),this 不再默认绑定到 windowglobalThis,而是明确设为 undefined。这是为了暴露错误,避免隐式绑定带来的歧义。

  • 非严格模式:this 指向 window(浏览器)或 globalThis(Node.js)
  • 严格模式:thisundefined —— 这是标准行为,不是 bug
  • 箭头函数没有自己的 this,它沿用外层函数作用域的 this 值,且无法被 call/apply/bind 修改

callapplybind 怎么影响 this

这三个方法都用于显式指定函数运行时的 this 值,但调用时机和返回结果不同:

  • func.call(obj, arg1, arg2):立即执行,参数逐个传入
  • func.apply(obj, [arg1, arg2]):立即执行,参数以数组形式传入
  • func.bind(obj, arg1):返回一个新函数,this 被永久绑定为 obj,后续调用不再受调用方式影响
  • 注意:bind 绑定后无法被再次覆盖(除非用 new 调用,见下条)

构造函数中 this 指向什么?

new 调用函数时,JS 引擎会自动创建一个空对象,并把 this 绑定到该对象上;如果函数显式返回一个对象,则 this 的绑定结果会被忽略(返回值优先)。

function Person(name) {
  this.name = name; // this 指向新创建的实例
  return { custom: true }; // 返回对象 → new 表达式结果就是这个对象
}
const p = new Person('Alice');
console.log(p.custom); // true
console.log(p.name);   // undefined
  • 没返回值或返回原始值(string/number/etc)→ this 对象作为返回值
  • 返回对象 → 忽略 this,以返回对象为准
  • 箭头函数不能用 new 调用,会抛出 TypeError: xxx is not a constructor

事件监听器里的 this 为什么有时不是预期对象?

DOM 事件回调中,this 默认指向触发事件的元素(event.currentTarget),但容易在异步或箭头函数中丢失:

  • element.addEventListener('click', handler)handler 中的 thiselement
  • handler 是箭头函数 → this 取外层作用域,通常不是 DOM 元素
  • handler 被解构或赋值给变量(如 const fn = obj.handleClick)→ 调用时失去原始 this,需用 bind 或事件回调中显式传参

最稳妥的方式是直接使用 event.currentTargetevent.target,而非依赖 this

理论要掌握,实操不能落!以上关于《JavaScript中this的正确使用方法解析》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

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