This的绑定规则有哪些?
时间:2026-04-28 13:16:04 115浏览 收藏
JavaScript 中的 this 并非静态绑定,而是在函数执行瞬间根据调用方式动态决定的——它既不取决于函数定义位置,也不继承外层作用域,只忠实地回应“谁在调用它”。本文系统梳理了四大绑定规则:默认绑定(严格模式下为 undefined,非严格模式指向全局对象)、隐式绑定(obj.method() 中 this 指向 obj,但易因赋值丢失上下文)、显式绑定(call/apply/bind 可手动且优先级更高地指定 this)以及优先级最高的 new 绑定(构造函数调用时 this 始终指向新创建的实例,甚至能覆盖已绑定的 this)。掌握这些规则,才能真正摆脱 this 的迷惑,写出可预测、健壮的 JavaScript 代码。

JavaScript 中的 this 不是写代码时就确定的,而是在函数**真正执行的那一刻**,根据**调用方式**动态决定的。它不取决于函数定义在哪,也不等于函数自身或外层作用域,只看“谁在调用它”。
默认绑定:最基础的兜底规则
当函数以最普通的方式被调用,既没挂对象上、也没用 new、call/apply/bind 时,就触发默认绑定:
- 非严格模式下:this 指向全局对象(浏览器是
window,Node 是global) - 严格模式下:this 是
undefined(这是 ES5 设计的本意,防止意外污染全局) - 常见例子:
function foo() { console.log(this); } foo();—— 直接调用,走默认绑定
隐式绑定:对象点号调用时的自然指向
函数作为对象的属性被调用,比如 obj.method(),这时 this 自动绑定到该对象:
- 关键看调用位置是否有“上下文对象”,即紧挨着点号(.)或方括号([])的那个对象
- 例如:
const obj = { name: 'Alice', say() { console.log(this.name); } }; obj.say();→ 输出Alice - 注意“隐式丢失”:把方法赋给变量再调用,
const fn = obj.say; fn();就不再有对象上下文,退回到默认绑定
显式绑定:手动指定 this 的三种方式
通过 call、apply、bind 主动传入一个对象作为 this 值:
func.call(obj, a, b)和func.apply(obj, [a, b]):立即执行,区别只在参数传法const bound = func.bind(obj):返回一个新函数,this 被永久固定为obj,后续调用无需再指定- 显式绑定优先级高于隐式绑定,但低于 new 绑定
new 绑定:构造函数调用时的特殊规则
用 new 调用函数时,会创建一个新对象,并把 this 绑定到这个新实例上:
- 过程包括:新建空对象 → 原型链链接 → this 绑定 → 执行函数体 → 返回对象(除非显式 return 非空对象)
- 例如:
function Person(name) { this.name = name; } const p = new Person('Bob');→p.name是'Bob' - new 绑定优先级最高,即使函数已用
bind固定 this,new仍会覆盖它
今天关于《This的绑定规则有哪些?》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
相关阅读
更多>
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
457 收藏
-
383 收藏
-
462 收藏
-
316 收藏
-
500 收藏
-
138 收藏
-
389 收藏
-
247 收藏
-
462 收藏
-
163 收藏
-
409 收藏
-
437 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习