javascript - 关于this的指向性问题
问题描述
var foo = 'window';var obj = { foo : 'obj', getFoo : function(){return function(){ return this.foo;}; }};var f = obj.getFoo();console.log(f()); //结果:window
为什么上述代码的运行结果是window呢?
问题解答
回答1:obj.getFoo() 返回一个方程,赋值给了 f 。f 通过 f() 被调用,没有明确的调用者,所以 this 就是 window 。
想要的到 'obj' ,可以这样做
var foo = 'window';var obj = { foo : 'obj', getFoo : function(){var self = this;return function(){ return self.foo;}; }};var f = obj.getFoo();console.log(f());回答2:
因为,在f()实际运行的地方,this是window,由于没有通过call或者bind改变上下文,所以输出的就是window。
可以按照如下替换方法:
console.log(f());// ----->console.log(obj.getFoo());// ----->console.log(function() { var self = this; return function() {return self.foo }});
这里的self就是指向window了,所以return self.foo就是return window.foo,也就是’window’。
回答3:其实最简单的理解就是obj.getFoo给了f,然后再看这方法运行的位置在哪.
f = function () { return function () {return this.foo }}回答4:
console.log(f())中f()是独立被调用的 1.如果调用者函数,被某一个对象所拥有,那么该函数在调用时,内部的this指向该对象。2.如果函数独立调用,那么该函数内部的this,则指向undefined。推荐阅读 http://www.jianshu.com/p/d647... 希望对你有所帮助
回答5:函数执行,函数体内的this指向函数的调用方
1、下面这段代码,getFoo函数的调用方是obj,所以getFoo函数内部的this指向obj对象
var f = obj.getFoo()
2、getFoo函数返回了一个匿名函数赋给变量f,再执行函数f,此时变量f是挂载到window上的,函数f的调用方是window,函数f内部的this也指向window
console.log(f()); //结果:window
相关文章:
1. $fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题2. python - 求一个在def中可以实现调用本def满足特定条件continue效果的方法(标题说不太清楚,请见题内描述)3. mysql - SQL操作时间的函数?4. MYSQL新建用户设置可以远程访问的问题5. javascript - 用表单提交两个时间段请求后台返回对应数据时出现的一些问题!6. angular.js - angularjs的自定义过滤器如何给文字加颜色?7. java - mybatis怎么实现在数据库中有就修改,没有就添加8. node.js - nodejs和前端JavaScript 字符串处理结果不一样是什么原因?9. docker api 开发的端口怎么获取?10. 正则表达式 - python pandas的sep参数问题
![$fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题](http://www.haobala.com/attached/image/news/202205/093622cb60.png)