《Professional Javascript For Web Developers 3rd Edition》读书笔记:javascript闭包中的this对象
通常,this对象指向函数运行时的上下文对象。当在全局函数中时,this指向window对象(非strict模式)或undefined(strict模式),当在对象函数中使用时,this指向这个对象。但是在匿名函数中,this并不指向该对象,而是window对象(非strict模式)。在javascript闭包中,这种情况尤为多见:
var name="The Window"; var object={ name:"My Object", getNameFunc:function(){ return function(){ return this.name; }; } }
alert(object.getNameFunc()());//"The Window"
为什么匿名函数中的this并不等同于该对象呢?原来,在每个function被调用的时候,自动就有了两个特殊的变量:this和arguments。但是,嵌套的内部函数不能直接获取外部函数中的this和arguments。有什么变通的方法?那就是将它们存到另外的变量中去,这样函数闭包就可以访问了:
var object={ name:"My Object", getNameFunc:function(){ var that = this; return function(){ return that.name; }; } } alert(object.getNameFunc()());//"My Object"
有时候,this会得到你意想不到的结果,比如:
var name="The Window"; var object={ name:"My Object", getName:function(){ return this.name; } } object.getName();//"My Object" (object.getName)();//"My Object" (object.getName=object.getName)();//"The Window"
第一行和第二行还好理解,结果不出所料,第三行就是奇葩了!只是执行了一次赋值,结果却截然不同。这是为什么呢?书上的解释是这样的:因为第三行的赋值表达式的值只是function本身,并没有维护this的值,所以就指向window对象了。当然,很少人会这么有雅兴用第三种方式写,只不过说明细微的语法差别会造成this结果的差异。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?