通俗易懂的LHS和RHS
在一段代碼執行之前,會經過編譯階段 。
在對程序的處理過程中,不可或缺的人物就是:引擎,編譯器,作用域。
JavaScript在預編譯后執行代碼時,引擎就會對其進行查詢,查詢分為:
LHS:Left-Hand-Side
RHS:Right-Hand-Side
即賦值的左側和右側:當出現在賦值操作的左側時進行LHS查詢,出現在右側時進行RHS查詢。
例:
在上述例子中,
像Kyle Simpson前輩一樣,我們可以將自己當作引擎然后去和作用域進行對話,然后就會發現:有3處LHS查詢,
分別是a=2 c=… b=…
有4處RHS查詢
分別是:
foo(2… =a a… …b
RHS查詢就相當于簡單地查找某個變量的值
LHS查詢是試圖找到變量的容器本身,從而可以對其進行賦值。
因此在此例中:
c的賦值操作需要對c進行一次LHS查詢,而對于foo(2)來說,需要進行一次RHS查詢,去獲取值.foo是一個函數,foo(a){},這里有一個隱式賦值操作,需要對a進行一次LHS查詢,判斷作用域中是否存在名為a的變量,若存在則直接賦值a=2;
不存在,(1)如果是嚴格模式下,則報ReferenceError:a is not defined.
(2)如果非嚴格模式,則創建一個a的全局變量,并直接賦值a=2;
在函數這個作用域內,var b = a;對b進行一次LHS查詢,對a進行一次RHS查詢
最終return a + b;需要分別對a和b進行RHS查詢。
當一個函數嵌套在另一個函數中,即作用域的嵌套。則:在當前作用域中無法找到某個變量時,引擎就會在外層嵌套的作用域中繼續查找,直到找到該變量或到達最外層的作用域為止。
例:
觀察上述例子,我們發現在函數內部無法對d進行RHS引用,則向外繼續查找,則在全局作用域中完成。
如何區分RHS和LHS
(1)若RHS查詢在所有嵌套的作用域中找不到所需的變量,則引擎就會拋出ReferenceError異常
(2)若是執行LHS查詢,若在全局作用域中也沒有找到所需變量,則:1.程序運行在非嚴格模式下:全局作用域會創建一個具有該名稱的變量,然后將其返回給引擎
2.程序運行在嚴格模式下:禁止自動或隱式地創建全局變量,因此引擎會拋出ReferenceError異常。
注:若查找的目的是對變量進行賦值,則使用LHS查詢
若查找的目的是獲取變量的值,則使用RHS查詢。
總結
以上是生活随笔為你收集整理的通俗易懂的LHS和RHS的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 规则引擎Drools使用 第十二篇 Dr
- 下一篇: iphoneX系列手机在页面滚动时隐藏底