在函数作用域嵌套下使用this
var myObj = {
specialFunction: function () {
console.log("specialFunction.");
},
anotherSpecialFunction: function () {
console.log("anotherSpecialFunction.");
},
getAsyncData: function (cb) {
cb();
},
render: function () {
//通常用法:将上下文this缓存到一个变量中
//以便在本函数作用域内包含另一个函数作用域的情况下可以继续使用此上下文对象this
//如果省略这行,那么在嵌套函数作用域内就无法访问到本函数作用域的成员了。
var that = this;
this.getAsyncData(function () {
that.specialFunction();
that.anotherSpecialFunction();
});
}
};
myObj.render();
//specialFunction.
//anotherSpecialFunction.
如果我们省略了var that = this,看看会是什么情况:
var myObj = {
specialFunction: function () {
console.log("specialFunction.");
},
anotherSpecialFunction: function () {
console.log("anotherSpecialFunction.");
},
getAsyncData: function (cb) {
cb();
},
render: function () {
this.getAsyncData(function () {
//需要说明的是:下面两行在IDE中用this是.不出来的,说明它们不在当前作用域中(或者说是上下文中)
//但是硬写上IDE中也不会报错,只在运行时会报错。
this.specialFunction();
this.anotherSpecialFunction();
});
}
};
myObj.render();
//TypeError: Object [object global] has no method 'specialFunction'
可以看出,因为嵌套函数之间没有继承关系,只有嵌套关系,所以一直查找到了全局作用域也没找到要调的方法。
有一种方法可以代替var that = this,它就是 Function.prototype.bind()
//下面我们改写代码:
var myObj = {
specialFunction: function () {
console.log("specialFunction.");
},
anotherSpecialFunction: function () {
console.log("anotherSpecialFunction.");
},
getAsyncData: function (cb) {
cb();
},
render: function () {
this.getAsyncData(function () {
this.specialFunction();
this.anotherSpecialFunction();
} .bind(this));
}
};
myObj.render();
//specialFunction.
//anotherSpecialFunction.
但是,很不幸,Function.prototype.bind 在IE8及以下的版本中不被支持。
关于Function.prototype.bind()的更多内容请见:http://blog.jobbole.com/58032/
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端