亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何理解Javascript的連續賦值運算

發布時間:2021-11-17 17:08:11 來源:億速云 閱讀:151 作者:柒染 欄目:web開發

這篇文章將為大家詳細講解有關如何理解Javascript的連續賦值運算,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

小編將分享一下作者在寫Javascript的心得,是關于連續賦值運算一些技巧。對大家在Web開發方面肯定有很大的啟發和幫助。

一、引子

var a = {n:1};     a.x = a = {n:2};     alert(a.x); // --> undefined

這是蔡蔡在看jQuery源碼 時發現這種寫法的。以上第二句 a.x = a = {n:2} 是一個連續賦值表達式。這個連續賦值表達式在引擎內部究竟發生了什么?是如何解釋的?

  二、猜想

猜想1:從左到右賦值,a.x 先賦值為{n:2},但隨后 a 賦值為 {n:2},即 a 被重寫了,值為 {n:2},新的 a 沒有 x屬性,因此為undefined。步驟如下

a.x = {n:2};   a = {n:2};

這種解釋得出的結果與實際運行結果一致,貌似是對的。注意猜想1中 a.x 被賦值過。

猜想2:從右到左賦值,a 先賦值為{n:2},a.x 發現 a 被重寫后(之前a是{a:1}),a.x = {n:2} 引擎限制a.x賦值,忽略了。步驟如下:

a = {n:2};  a.x 未被賦值{n:2}

等價于 a.x = (a = {n:2}),即執行了***步,這樣也能解釋a.x為undefined了。注意猜想2中a.x壓根沒被賦值過。

  三、證明

上面兩種猜想相信多數人都有,群里討論呆呆認為是猜想1, 我認為是猜想2。其實都錯了。我忽略了引用的關系。如下,加一個變量b,指向a。

Js代碼

var a = {n:1};     var b = a; // 持有a,以回查     a.x = a = {n:2};     alert(a.x);// --> undefined     alert(b.x);// --> [object Object]

發現a.x仍然是undefined,神奇的是 b.x 并未被賦值過(比如:b.x={n:2}),卻變成了[object Object]。b 是指向 a({n:1})的,只有a.x = {n:2}執行了才說明b是有x屬性的。實際執行過程:從右到左,a 先被賦值為{n:2},隨后a.x被賦值{n:2}。

a = {n:2};  a.x = {n:2};

等價于

a.x = (a = {n:2});

  與猜想2的區別在于a.x 被賦值了,猜想2中并未賦值。最重要的區別,***步 a = {n:2} 的 a 指向的是新的對象{n:2} , 第二步 a.x = {n:2} 中的 a 是 {a:1}。即在這個連等語句

Js代碼

a.x = (a = {n:2});

a.x 中的a指向的是 {n:1},a 指向的是 {n:2}。如下圖

如何理解Javascript的連續賦值運算

  四:解惑

這篇寫完,或許部分人看完還是暈暈的。因為里面的文字描述實在是繞口。最初我在理解這個連等賦值語句時

Js代碼

var a = {n:1};     a.x = a = {n:2};

認為引擎會限制a.x的重寫(a被重寫后),實際卻不是這樣的。指向的對象已經不同了。引擎也沒有限制a.x={n:2}的重寫。

謝謝所有參與討論的人:蔡蔡、豬大腸 、呆呆、雅儒。這個問題最早是蔡蔡提出的。雅儒在 菜鳥灰呀灰 群里每次的討論都那么投入,認真,哪怕是別人提出的話題。

五:結束

呵,以另一個連續賦值題結束。fun執行后,這里的 變量 b 溢出到fun外成為了全局變量。想到了嗎?

Js代碼

function fun(){         var a = b = 5;     }     fun();     alert(typeof a); // --> undefined     alert(typeof b); // --> number

關于如何理解Javascript的連續賦值運算就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

毕节市| 苍溪县| 青州市| 留坝县| 驻马店市| 图木舒克市| 卢氏县| 桃园县| 长垣县| 沧源| 福安市| 成都市| 彰化市| 黄浦区| 余干县| 九寨沟县| 平山县| 鄂伦春自治旗| 平顶山市| 名山县| 佛山市| 光泽县| 商丘市| 罗田县| 东港市| 滦南县| 谢通门县| 罗平县| 威海市| 灵丘县| 观塘区| 南乐县| 宁河县| 邵阳市| 奇台县| 郸城县| 陇川县| 涟水县| 剑河县| 泾阳县| 和龙市|