国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

javascript引用類型指針的工作方式

2019-11-20 12:42:32
字體:
來源:轉載
供稿:網友

先看個例子:

 <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>

上面的例子看似簡單,但結果并不好了解,很容易把人們給想繞了――“a.x不是指向對象a了么?為啥log(a.x)是undefined?”、“b.x不是應該跟a.x是一樣的么?為啥log出來居然有2個對象”

當然各位可以先自行理解一下,若能看出其中的原因和工作機理自然就無須繼續往下看啦。

下面來分析下這段簡單代碼的工作步驟,從而進一步理解js引用類型“賦值”的工作方式。

首先是

var a = {n:1}; 
var b = a;

在這里a指向了一個對象{n:1}(我們姑且稱它為對象A),b指向了a所指向的對象,也就是說,在這時候a和b都是指向對象A的:

這一步很好理解,接著繼續看下一行非常重要的代碼:

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

我們知道js的賦值運算順序永遠都是從右往左的,不過由于“.”是優先級最高的運算符,所以這行代碼先“計算”了a.x。

這時候發生了這個事情――a指向的對象{n:1}新增了屬性x(雖然這個x是undefined的):

從圖上可以看到,由于b跟a一樣是指向對象A的,要表示A的x屬性除了用a.x,自然也可以使用b.x來表示了。

接著,依循“從右往左”的賦值運算順序先執行 a={n:2} ,這時候,a指向的對象發生了改變,變成了新對象{n:2}(我們稱為對象B):

接著繼續執行 a.x=a,很多人會認為這里是“對象B也新增了一個屬性x,并指向對象B自己”

但實際上并非如此,由于一開始js已經先計算了a.x,便已經解析了這個a.x是對象A的x,所以在同一條公式的情況下再回來給a.x賦值,也不會說重新解析這個a.x為對象B的x。

所以 a.x=a 應理解為對象A的屬性x指向了對象B:

那么這時候結果就顯而易見了。當console.log(a.x)的時候,a是指向對象B的,但對象B沒有屬性x。沒關系,當查找一個對象的屬性時,JavaScript 會向上遍歷原型鏈,直到找到給定名稱的屬性為止。但當查找到達原型鏈的頂部 - 也就是 Object.prototype - 仍然沒有找到指定的屬性B.prototype.x,自然也就輸出undefined;

而在console.log(b.x)的時候,由于b.x表示對象A的x屬性,該屬性是指向對象B,自然也輸出了[object Object]了,注意這里的[object Object]可不是2個對象的意思,對象的字符串形式,是隱式調用了Object對象的toString()方法,形式是:"[object Object]"。所以[object Object]表示的就只是一個對象罷了

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 玉门市| 于田县| 革吉县| 渝中区| 兴和县| 荃湾区| 武义县| 巴南区| 眉山市| 小金县| 凭祥市| 汤阴县| 翁源县| 郓城县| 土默特左旗| 玉树县| 凌云县| 昌黎县| 玉林市| 广南县| 高清| 从化市| 河源市| 浮梁县| 松潘县| 罗田县| 丹巴县| 武隆县| 思南县| 海安县| 黄骅市| 阿瓦提县| 广灵县| 华宁县| 乐昌市| 凤山市| 兖州市| 东方市| 河南省| 资溪县| 芦溪县|