javascript - 这段代码如何理解?
问题描述
var name = '123'; var object = {name: 'My Object',getNameFunc: function() { return this.name;} } console.log(object.getNameFunc()); //My Object console.log((object.getNameFunc)());//My Object console.log((object.getNameFunc = object.getNameFunc)()); //123
为啥最后输出的是123?object.getNameFunc = object.getNameFunc是什么意思?
问题解答
回答1:看错问题了,那我重新解释吧。
首先看 object.getNameFunc,它的定义是
function () { return this.name}
当你这样写的时候 object.getNameFunc = object.getNameFunc 的时候,其实可以看成是这样的。
object.getNameFunc = function () { return this.name}
其实在做这样一个事情的时候,this 已经不是 object 了。而是 window(在浏览器里)了。所以输出的是外面的 name。
大概是这样= =
回答2:赋值运算结果是左值。
因此(object.getNameFunc = object.getNameFunc)()可以认为是:
var f = (object.getNameFunc = object.getNameFunc); f();
因此 this 指向全局了 所以得到 123
回答3:var name = '123';var obj = { name: 'My Object', getNameFunc: function() {return this.name; }}console.log(obj.getNameFunc()); //My Objectconsole.log((obj.getNameFunc)());//My Objectconsole.log((obj.getNameFunc = obj.getNameFunc)()); //123console.log((obj.getNameFunc = obj.getNameFunc));
从this引用结果来看,肯定是this是指向全局了,可能中间有些环节没搞明白。我们在后面加一段代码,就能知道(obj.getNameFunc = obj.getNameFunc)这段内容是什么了,没错,console出了一个函数,所以(obj.getNameFunc = obj.getNameFunc)这段语句执行结果就是一个函数,惯性思维导致我们总想当然认为这只是一次重赋值操作,认为依旧是obj来调用函数。其实当执行完语句后,这段函数其实是由全局对象调用的。
相关文章:
1. 主从备份 - 跪求mysql 高可用主从方案2. python - django 里自定义的 login 方法,如何使用 login_required()3. python如何不改动文件的情况下修改文件的 修改日期4. android-studio - Android 动态壁纸LayoutParams问题5. javascript - git clone 下来的项目 想在本地运行 npm run install 报错6. angular.js - 不适用其他构建工具,怎么搭建angular1项目7. mysql主从 - 请教下mysql 主动-被动模式的双主配置 和 主从配置在应用上有什么区别?8. mysql优化 - mysql count(id)查询速度如何优化?9. node.js - 使用 superagent 抓取 UTF-8网站乱码10. sql语句如何按or排序取出记录
