登录
首页 >  文章 >  前端

JS中this关键字是什么?如何确定指向?

时间:2026-04-01 20:27:27 378浏览 收藏

JavaScript 中的 this 是一个动态绑定的关键字,其值并非由函数定义决定,而是完全取决于函数**如何被调用**——普通调用时受严格模式影响(非严格指向全局对象,严格模式为 undefined),对象方法调用时指向该对象,call/apply/bind 可显式绑定任意对象,而箭头函数则彻底摒弃动态绑定,直接继承外层词法作用域的 this。掌握 this 的四大绑定规则,是写出可预测、无坑 JavaScript 代码的关键一步。

Javascript的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

本篇关于《JS中this关键字是什么?如何确定指向?》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!

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