链家前端选择题求解答

链家前端选择题求解答
var a = 0;
function A() {
this.a = 1;
setTimeout(function() {
this.a = 2;
try{
this.a = 'b';
throw '';
}catch(e) {
this.b = 'bb';
}
},0)
this.b = 'bbb';
}
var aa = new A();
setTimeout(function() {
console.log(aa.a);
console.log(window.a);
console.log(aa.b);
console.log(window.b);
},0);
#前端工程师#
全部评论
详细说下,在构造函数 A 里面的,this 指向 new 出来的新对象,所以后面输出的 aa.a 是 1,aa.b 是 'bbb'。而 setTimeout 里面的 this 是指向全局对象的,这里就是 window,所以 window.a 是 'b',window.b 是 'bb'
点赞 回复 分享
发布于 2017-08-19 20:29
刚才弄错输出顺序...1,'b','bbb','bb'
点赞 回复 分享
发布于 2017-08-19 20:24
你编程完了么
点赞 回复 分享
发布于 2017-08-19 20:21
点赞 回复 分享
发布于 2017-08-19 20:19

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务