JS对象中的方法的this指向
<script> // 对象里的方法写的是箭头函数,this始终访问全局 var name = "xiaoming"; var obj1 = { name: "xiaohong", getName: () => { console.log(this.name); }, }; obj1.getName(); // xiaoming let getName1 = obj1.getName; getName1(); // xiaoming let getName11 = obj1.getName.bind(obj1); getName11(); // xiaoming // 对象的方法写的 function 声明,直接调用 this 指向对象本身,将调用的方法单独保存起来调用,this 指向全局,通过bind 改写 this 指向后,可以继续指向 对象本身 var obj2 = { name: "xiaohong", getName: function () { console.log(this.name); }, }; obj2.getName(); // xiaohong let getName2 = obj2.getName; getName2(); // xiaoming let getName22 = obj2.getName.bind(obj2); getName22(); // xiaohong
obj2.getName.call(obj2); // xiaohong
</script>
分类:
javascript
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南