this 是 JavaScript 中动态绑定的关键字,其值取决于函数调用方式:普通调用时非严格模式指向全局对象、严格模式为 undefined;对象方法调用时指向该对象;call/apply/bind 可显式绑定;箭头函数无自有 this,继承外层词法作用域的 this。

this 是 JavaScript 中一个特殊的关键字,它不是一个固定值,而是在函数被调用时才动态确定的,指向**当前执行上下文中的对象**。它的具体指向不取决于函数如何定义,而取决于函数**如何被调用**。
普通函数调用时的 this(非严格模式 vs 严格模式)
直接调用函数(如 foo()),没有点号或绑定:
对象方法调用时的 this(最常见的场景)
当函数作为对象的属性被调用(即通过点号或方括号访问后加括号),this 指向**该对象本身**:
-
obj.method()→this指向obj -
obj['method']()→ 同样指向obj - 注意:一旦把方法单独提取出来(如
const fn = obj.method;),再调用fn()就变成普通调用,this不再是obj
显式绑定 this 的方式(call、apply、bind)
可以通过这三个内置方法强制指定函数运行时的 this 值:
本文档主要讲述的是Python开发网站指南;HTML是网络的通用语言,一种简单、通用的全置标记语言。它允许网页制作人建立文本与图片相结合的复杂页面,这些页面可以被网上任何其他人浏览到,无论使用的是什么类型的电脑或浏览器 Python和其他程序语言一样,有自身的一套流程控制语句,而且这些语句的语法和其它程序语言类似,都有for, if ,while 类的关键字来表达程序流程。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看
立即学习“Java免费学习笔记(深入)”;
-
func.call(obj, arg1, arg2)—— 立即执行,参数逐个传入 -
func.apply(obj, [arg1, arg2])—— 立即执行,参数以数组形式传入 -
const bound = func.bind(obj)—— 返回一个新函数,永久绑定this为obj
箭头函数没有自己的 this
箭头函数不创建自己的执行上下文,它会**继承外层普通函数作用域中的 this**(词法绑定):
- 在对象方法中写箭头函数,
this不指向该对象,而是指向定义时所在上下文的this - 常用于避免回调中
this失去绑定(比如事件处理、定时器、Promise 链) - 不能用
call/apply/bind改变箭头函数的this









