百度HR给的JS面试题

说出以下代码运行结果

var a = {n: 1}  
var b = a;  
a.x = a = {n: 2}  
console.log(a.x);  
console.log(b.x)  


输出:
undefined
n:2


解析:
var a = {n: 1}    // 定义变量 a 为一个新对象,且这个新对象有一个值为 1 的 n 成员
var b = a;    // 定义变量 b ,并且让 b 也引用变量 a 的对象
// 经过上面这两句之后,变量 a 和 b 都引用了对象 {n:1}

// 下面这句是问题的关键
a.x = a = {n: 2}
// a.x = 表示要给 a 引用的那个对象 {n:1} 的 x 成员赋值
// 实际上,此时变量 b 也引用了这个对象 {n:1}
// 此时,JavaScript引擎首先给 {n:1} 添加一个空的 x 成员,即:{n:1,x:undefined}
// 接下来要给{n:1,x:undefined}.x 赋的是什么值呢?
// 要赋的值是 a = {n: 2}
// 也就是先让变量 a 引用一个新的对象 {n:2}
// 然后再把 a 的新值赋给{n:1,x:undefined}.x
// 所以原来的那个对象变成了 {n:1,x:{n:2}}
// 由于变量 b 始终引用那个原来的对象,所以 b 的值是 {n:1,x:{n:2}}
// 由于变量 a 被赋予了一个新的对象,所以 a 的值是 {n:2}

// 这面这两句是控制台输出
console.log(a.x);    //变量 a 引用的对象是 {n:2},没有 x 成员,所以输出 undefined
console.log(b.x);    // 变量 b 引用的对象是{n:1,x:{n:2}},所以输出 {n:2}

需要web前端课程工具和电子书,可以加22群120342833

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值