摘要:看如下对象定义这样能正常调用下面的调用会出错因为,指向已经改变,正确的方式如下所有函数都有其特殊的变量,如下面的调用会产生一个错误解决方案一将保存在不同的变量中解决方案二利用的第二个参数,它可以给指定一个值
看如下对象定义:
"use strict" var jane = { name : ‘Jane’, display : function(){ retrun "Person named " + this.name; } };这样能正常调用
下面的调用会出错:jane.display();
因为,this指向已经改变,正确的方式如下:var func = jane.display;
func()
TypeError: Cannot read property "name" of undefined
所有函数都有其特殊的this变量,如下面的forEachvar func2 = jane.display.bind(jane);
func2()
"Penson named Jane"
var jane = { name : "Jane", friends: ["Tarzan", "Cheeta"], sayHiToFriends: function(){ "use strict"; this.friends.forEach(function(friend) { // "this" is undefined here console.log(this.name + " says hi to "+ friend); }); } }调用sayHiToFriends会产生一个错误:
解决方案一:将this保存在不同的变量中jane.sayHiToFriends()
TypeError: Cannot read property "name" of undefined
var jane = { name : "Jane", friends: ["Tarzan", "Cheeta"], sayHiToFriends: function(){ "use strict"; var that = this; this.friends.forEach(function(friend) { console.log(that.name + " says hi to "+ friend); }); } }解决方案二:利用forEach的第二个参数,它可以给this指定一个值
var jane = { name : "Jane", friends: ["Tarzan", "Cheeta"], sayHiToFriends: function(){ "use strict"; this.friends.forEach(function(friend) { console.log(this.name + " says hi to "+ friend); }, this); } }
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/79073.html
摘要:要达到想要的效果正确的做法是即用来产生一个立即作用域,保证回调函数执行的时候最近的原型作用域的就是当时循环的。判断数组中是否存在满足条件的项,只要有一项满足条件,就会返回。 之前常常因为不注意,习惯用写PHP或者Java的方式来写nodejs,产生了了一些错误,这里总结一些小小的trick,以便于展示nodejs的不同,和平时需要注意的地方。 变量提升 var variable = g...
摘要:系列文章的人懒事多,最近翻多写少啊。不过当我们调试我们自己的脚本的时候也会一不小心跳到这些文件中,引发额外的调试任务。 系列文章的Github Repo人懒事多,最近翻多写少啊。原文地址这里 ‘debugger;’ 除了console.log,debugger就是另一个我很喜欢的快速调试的工具,将debugger加入代码之后,Chrome会自动在插入它的地方停止,很像C或者Java里面...
摘要:没有安装全局某个项目不影响该命令的使用。该标志会安装,忽略。这会确保开发所使用的工具及不会进入生产环境。结果就是,发布项目时,不得不审查两个文件是否同步,防止敏感信息的泄露。确保更改默认的用户名,作为用户名环境变量的值。 本文转载自:众成翻译译者:文蔺链接:http://www.zcfy.cc/article/1206原文:https://nodesource.com/blog/ele...
阅读 1641·2021-10-27 14:13
阅读 1882·2021-10-11 10:59
阅读 3379·2021-09-24 10:26
阅读 1935·2019-08-30 12:48
阅读 3045·2019-08-30 12:46
阅读 2042·2019-08-30 11:16
阅读 1425·2019-08-30 10:48
阅读 2749·2019-08-29 16:54