ES6的箭头函数,箭头函数不会创造块作用域,无法生成一个独立的环境,this指向上层的this

var color = 'green'; var test4399 = { color: 'blue', getColor: function(){ var color = "red"; alert(this.color); } } var getColor = test4399.getColor; getColor(); test4399.getColor();

以上 JavaScript 代码执行后, 浏览器 alert 出来的结果分别是

A
undefined,red

B
green,blue

C
undefined,blue

D
green,undefined

E
blued,undefined

正确答案:B

1.getColor() var getColor = test4399.getColor;
即var getColor = function(){var color = "red";alert(this.color);};
执行getColor()函数时this指向的window,因为window.color为green,所以弹出green

2.test4399.getColor(),此时this指向的是test4399,test4399.color为blue,所以弹出blue

getColor();相当于普通的函数调用,此时this指向window,this.color应该为全局变量的值

test4399.getColor();此时this指向调用函数的对象test4399,因此this.color应该为对象的属性值

这题的重点只是this关键字的用法,指向运行时的对象,而不是定义时的对象,表示函数的运行时。
作为总结:
1、函数作为对象的方法被调用,this指向调用者!
2、用于构造函数,this指向新对象
3、ES6的箭头函数,箭头函数不会创造块作用域,无法生成一个独立的环境,this指向上层的this


__EOF__

本文作者龙陌
本文链接https://www.cnblogs.com/longmo666/p/17832277.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   龙陌  阅读(25)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示