javascript引用類型指針的工作方式
先看個例子:
<script> var a = {n:1}; var b = a; a.x = a = {n:2}; console.log(a.x);// --> undefined console.log(b.x);// --> [object Object] </script>
上面的例子看似簡單,但結(jié)果并不好了解,很容易把人們給想繞了——“a.x不是指向?qū)ο骯了么?為啥log(a.x)是undefined?”、“b.x不是應該跟a.x是一樣的么?為啥log出來居然有2個對象”
當然各位可以先自行理解一下,若能看出其中的原因和工作機理自然就無須繼續(xù)往下看啦。
下面來分析下這段簡單代碼的工作步驟,從而進一步理解js引用類型“賦值”的工作方式。
首先是
var a = {n:1};
var b = a;
在這里a指向了一個對象{n:1}(我們姑且稱它為對象A),b指向了a所指向的對象,也就是說,在這時候a和b都是指向?qū)ο驛的:
這一步很好理解,接著繼續(xù)看下一行非常重要的代碼:
a.x = a = {n:2};
我們知道js的賦值運算順序永遠都是從右往左的,不過由于“.”是優(yōu)先級最高的運算符,所以這行代碼先“計算”了a.x。
這時候發(fā)生了這個事情——a指向的對象{n:1}新增了屬性x(雖然這個x是undefined的):
從圖上可以看到,由于b跟a一樣是指向?qū)ο驛的,要表示A的x屬性除了用a.x,自然也可以使用b.x來表示了。
接著,依循“從右往左”的賦值運算順序先執(zhí)行 a={n:2} ,這時候,a指向的對象發(fā)生了改變,變成了新對象{n:2}(我們稱為對象B):
接著繼續(xù)執(zhí)行 a.x=a,很多人會認為這里是“對象B也新增了一個屬性x,并指向?qū)ο驜自己”
但實際上并非如此,由于一開始js已經(jīng)先計算了a.x,便已經(jīng)解析了這個a.x是對象A的x,所以在同一條公式的情況下再回來給a.x賦值,也不會說重新解析這個a.x為對象B的x。
所以 a.x=a 應理解為對象A的屬性x指向了對象B:
那么這時候結(jié)果就顯而易見了。當console.log(a.x)的時候,a是指向?qū)ο驜的,但對象B沒有屬性x。沒關系,當查找一個對象的屬性時,JavaScript 會向上遍歷原型鏈,直到找到給定名稱的屬性為止。但當查找到達原型鏈的頂部 - 也就是 Object.prototype - 仍然沒有找到指定的屬性B.prototype.x,自然也就輸出undefined;
而在console.log(b.x)的時候,由于b.x表示對象A的x屬性,該屬性是指向?qū)ο驜,自然也輸出了[object Object]了,注意這里的[object Object]可不是2個對象的意思,對象的字符串形式,是隱式調(diào)用了Object對象的toString()方法,形式是:"[object Object]"。所以[object Object]表示的就只是一個對象罷了
以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。
- JavaScript之引用類型介紹
- Js從頭學起(基本數(shù)據(jù)類型和引用類型的參數(shù)傳遞詳細分析)
- js中的值類型和引用類型小結(jié) 文字說明與實例
- JavaScript中值類型與引用類型實例說明
- js類型轉(zhuǎn)換與引用類型詳解(Boolean_Number_String)
- js中判斷Object、Array、Function等引用類型對象是否相等
- JavaScript入門教程之引用類型
- JavaScript學習筆記整理之引用類型
- JavaScript引用類型和基本類型詳解
- 詳解JavaScript基本類型和引用類型
- JavaScript基礎篇(3)之Object、Function等引用類型
- 跟我學習javascript的基本類型和引用類型
- 《JavaScript高級編程》學習筆記之object和array引用類型
- JavaScript中各種引用類型的常用操作方法小結(jié)
相關文章
JavaScript為事件句柄綁定監(jiān)聽函數(shù)實例詳解
這篇文章主要介紹了JavaScript為事件句柄綁定監(jiān)聽函數(shù)的方法,結(jié)合實例詳細分析了常見的事件句柄綁定監(jiān)聽函數(shù)的實現(xiàn)技巧,并實例講解了跨瀏覽器的實現(xiàn)方法,需要的朋友可以參考下2015-12-12js實現(xiàn)仿愛微網(wǎng)兩級導航菜單效果代碼
這篇文章主要介紹了js實現(xiàn)仿愛微網(wǎng)兩級導航菜單效果代碼,通過javascript自定義函數(shù)結(jié)合鼠標點擊事件實現(xiàn)tab切換的功能,具有一定參考借鑒價值,需要的朋友可以參考下2015-08-08undefined==null引發(fā)的兩者區(qū)別與聯(lián)系
undefined==null引發(fā)的兩者區(qū)別與聯(lián)系2007-12-12JS數(shù)組轉(zhuǎn)字符串實現(xiàn)方法解析
這篇文章主要介紹了JS數(shù)組轉(zhuǎn)字符串實現(xiàn)方法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-09-09