javascript连等赋值问题

本文探讨了JavaScript中连等赋值的问题,通过一道题目揭示了属性运算优先于赋值运算的特性,并详细解释了为何代码执行后foo.x的值为undefined,帮助读者理解这种特殊的赋值行为。

关于javascript连等赋值问题可以看一道题:
下面代码执行后,foo.x的值是 ?( )

var foo = {n: 1};
var bar = foo;
foo.x = foo = {n: 2};

相信大多数人思考过后给出的答案foo.x的值为{n: 2},但事实上foo.x的值为undefined.
首先我们要知道一个概念就是:. 属性运算优先高于=赋值运算,且赋值从右到左,于是可以这样来拆分代码:

var foo = {n:1};
var bar = foo;
//此时foo与bar具有相同的引用,即bar = {n:1};
foo.x = foo = {n: 2};
//由于.属性运算优先高于=赋值运算
//第三行代码可看作:foo = foo.x = {n:2};
// 再次拆分一下:
//foo.x = {n:2}; 此时对象foo具有属性x,同时bar与foo具有相同的引用也具有了属性x,所以 bar = {n:1,x:{n:2}};
//foo = {n:2};  对象foo重新赋值为{n:2}
//因此
console.log(foo.x);//undefined
console.log(bar.x);//{n:2}

这样你懂了吗?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值