js 連續(xù)賦值的簡單實現(xiàn)
無意中網(wǎng)上發(fā)現(xiàn)的這個問題,預想的結果和真實的結果大相徑庭。
var a={n:1} var b=a; a.x=a={n:2} console.log(a.x); console.log(b.x);
undefined Object{n:2}
要是拆開來看,結果就是我所想的那樣
var a={n:1} var b=a; a={n:2}; a.x={n:2} console.log(a.x);//Object{n:2}console.log(b.x);//undefined
分析:
a.x=a={n:2}
js的賦值運算是右結合的,上面等同于a.x=(a={n:2})
js的求值運算是從左到右的(PS:和同事討論,他說是從左到右,我認為是從右到左,最后發(fā)現(xiàn)是我錯了)
1)a.x=(括號內(nèi)的最終結果)
查找a的x屬性不存在后在a指向的對象中添加一個屬性x,這個x屬性要把一個結果賦給它,那好吧,我等著結果
2)因為是要獲得括號內(nèi)的結果,那么a.x就一直等著括號內(nèi)給他返回結果,所以開始求值a={n:2}得到結果后返回給這個新屬性x
3)回到括號內(nèi)的a={n:2},a發(fā)生指向改變了
以上這篇js 連續(xù)賦值的簡單實現(xiàn)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
javascript實現(xiàn)一個網(wǎng)頁加載進度loading
本篇文章主要介紹了javascript實現(xiàn)一個頁面加載進度loading的具體步驟以及示例代碼,具有一定的參考價值,下面跟著小編一起來看下吧2017-01-01BootStrap 動態(tài)添加驗證項和取消驗證項的實現(xiàn)方法
這篇文章主要介紹了BootStrap 動態(tài)添加驗證項和取消驗證項的實現(xiàn)方法的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-09-09通過event對象的fromElement屬性解決熱區(qū)設置主實體的一個bug
后臺的熱區(qū)管理中,如果鼠標移到熱區(qū)上,會顯示一個提示框,提示框里“設為主實體”、“刪除”和“合并”等超鏈接,點擊這些超鏈接可以進行各種操作。2008-12-12