牛客467289号 level
获赞
57
粉丝
0
关注
0
看过 TA
0
西安邮电大学
2017
前端工程师
IP属地:陕西
暂未填写个人简介
私信
关注
var a=10; var foo={ a:20, bar:function(){ var a=30; return this.a; } } foo.bar() //20 (foo.bar)() //20 (foo.bar=foo.bar)() //10 (foo.bar,foo.bar)() //10 一直对this都是一知半解的,四项运行出来是这个结果。有点不太清楚为什么,求大神解答
菜鸟葫芦娃:   在 ECMAScript 中,要掌握的最重要的概念之一是关键字 this 的用法,它用在对象的方法中。关键字 this 总是指向调用该方法的对象。简单说的就是调用了该方法this就是谁。 var a=10; var foo={ a:20, bar:function(){ var a=30; return this.a;//this指向调用该方法的对象 } } foo.bar() foo调用了bar这个函数,this 指向的是foo,然后foo里面有个对象a,this.a其实就是foo.a。 输出的结果为20 (foo.bar)() foo.bar 是一个匿名函数,调用这个匿名函数使用的是(),this指向这个匿名函数,但是这个匿名函数仅限于foo里面的全局变量使用,此时this.a就是foo里面的全局变量a. 和上面的调用方法是等价 this指向的就是foo这个对象。输出为20 (foo.bar=foo.bar)() 根据=从右向左进行赋值 把右边的foo.bar赋值到左边的foo.bar 等价于把右边的匿名函数重新赋值给脸foo.bar 此时 foo.bar整体相当于一个全局变量,这个变量是一个函数性质的变量,再用()调用这个函数时 this指向的是全局变量中的a 输出的是10。可以这么理解: var b = foo.bar; b() 输出的就是10 这个和上面的区别是使用了=号赋值(此时会改变this的指向)操作,上面那个没有进行=号赋值,后面直接进行调用的foo.bar这个匿名函数。 (foo.bar,foo.bar)() 理解了逗号运算符 就理解这个调用过程,相当于调用 左边foo.bar的匿名函数 剩下的就是和第二个调用的过程一样了。 这是js里面的逗号运算符 逗号运算符参考: http://m.blog.csdn.net/blog/liaozhongping/46770249 http://www.zhihu.com/question/27620371 可以参考这篇文章理解: http://www.nowcoder.com/discuss/2085
0 点赞 评论 收藏
分享

创作者周榜

更多
关注他的用户也关注了:
牛客网
牛客企业服务