您好,登錄后才能下訂單哦!
JavaScript 程序中的一段源代碼在執行之前會經歷三個步驟,統稱為 編譯
先看原書對一個賦值操作的拆解說明:
變量的賦值操作會執行兩個動作,首先編譯器會在當前作用域中聲明一個變量(如果之前沒有聲明過),然后在運行時引擎會在作用域中查找該變量,如果能夠找到就會對它賦值。 --- 《你不知道的JavaScript(上卷)》 P7
而要講的 LHS 和 RHS 就是上面說的對變量的兩種查找操作,查找的過程是由作用域(詞法作用域)進行協助,在編譯的第二步中執行。
LHS 和 RHS
Left Hand Side
和 Right Hand Side
即左手邊和右手邊 賦值操作的左側和右側
先看個例子一
console.log(a);
這里對 a 是一個 RHS 引用,因為 a 并沒有賦予任何值,目的是為了取到 a 的值并打印出來。
a = 2;
這里對 a 是一個 LHS 引用,因為實際上我們不關心當前的值是什么,只是想要把 a 賦值為 2。
再看例子二
function foo(a) { console.log(a); // 2 } foo(2);
小測驗
function foo(a) { var b = a; return a + b; } var c = foo(2);
試試找出其中的3處 LHS 查詢,4處 RHS 查詢
答案:
LHS 查詢:
c = ..;
a = 2(隱式變量分配)
b = ..
RHS 查詢
foo(2..
= a;
a ..
.. b
小結
參考原書中文版P12,英文版見 github
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。