关于JS中的this指向问题

全局代码中调用this

全局代码中调用this,this都指向window对象,如果是nodejs 中this指向global

方法内部调用this

在方法内部调用this并不能马上获取this的指向,具体要看当前方法是如何调用的

|---------|------------------------------------------|----------------|
| 调用方式 | 调用示例 | this指向 |
| 通过new调用 | const obj = new Method() | this 指向obj |
| 直接调用 | function obj() { console.log(this) } | this指向window |
| 通过对象调用 | obj.fun = function() {console.log(this)} | this指向调用对象 obj |
| 通过call | fun.call(this, ...args) | 用户手动设置 |
| 通过apply | fun.apply(this, [...args]) | 用户手动设置 |
[ ]

调用示例:👇

javascript 复制代码
const User = function() {
    console.log(this) // 指向 User {}
}
const user = new User()
javascript 复制代码
function user() {
    console.log(this) // 指向 window
}
user()
javascript 复制代码
const user = {
    name: '小妹',
    age: 18,
    sayHello: function() {
        console.log(this) // 指向user 
    }
}

user.hello()
javascript 复制代码
const user = {
    name: '小妹',
    age: 18,
    sayHello: function() {
        console.log(this) // 指向window
    }
}

user.hello.call(this)
user.hello.apply(this)
相关推荐
q***44811 分钟前
Java进阶10 IO流
java·开发语言
济宁雪人7 分钟前
Java安全基础——文件系统安全
java·开发语言·安全
Charles_go8 分钟前
C#中级46、什么是模拟
开发语言·oracle·c#
20岁30年经验的码农12 分钟前
Java RabbitMQ 实战指南
java·开发语言·python
共享家952726 分钟前
QT-界面优化(下)
开发语言·数据库·qt
蚂蚁集团数据体验技术27 分钟前
一个可以补充 Mermaid 的可视化组件库 Infographic
前端·javascript·llm
合作小小程序员小小店28 分钟前
游戏开发,桌面%小游戏,俄罗斯方块%demo,基于vs2022,c语言,背景音乐,easyX,无数据库,
c语言·开发语言
2739920291 小时前
生成二维码 QRCode (QT)
开发语言·qt
火山灿火山1 小时前
初识Qt(使用不同中方式创建helloworld)
开发语言·qt
华仔啊1 小时前
还在用 WebSocket 做实时通信?SSE 可能更简单
前端·javascript