淺聊一下JavaScript中的LHS和RHS查詢
前言
在日常編碼中,我們通常關(guān)注代碼的邏輯和功能,但很少深入思考編譯器在幕后的工作。今天我們將學(xué)習(xí)一下LHS(Left-Hand Side)和RHS(Right-Hand Side)查詢,它們在JavaScript編譯和執(zhí)行中的關(guān)鍵作用,以及在我們的日常開發(fā)中是如何發(fā)揮作用的。
接下來就讓我們來淺淺學(xué)習(xí)一下LHS和RHS
正文
很明顯L
為left,R
為right
所以我們大概可以猜到,用這樣一句話解釋:
當(dāng)變量出現(xiàn)在賦值操作的左側(cè)時進行LHS查詢,出現(xiàn)在右側(cè)時進行RHS查詢。
說得更簡單點RHS查詢與簡單地查找某個變量的值別無二致,而LHS查詢則是試圖找到變量的容器本身,從而可以對其賦值。
LHS查詢的學(xué)習(xí)
1. LHS查詢的概述
- LHS查詢涉及變量的存儲和初始化,是賦值操作的左側(cè)操作數(shù)。
- 編譯器如何處理LHS查詢,從變量聲明到內(nèi)存分配的全過程。
我們來看這個案例!
var name = "John"; // 在這個例子中,LHS查詢負(fù)責(zé)為變量name分配內(nèi)存并將其初始化為"John"
RHS查詢的學(xué)習(xí)
1. RHS查詢的本質(zhì)
- RHS查詢是獲取變量值的右側(cè)操作數(shù),是為了得到變量的值。
- 編譯器如何在RHS查詢中找到變量的值并傳遞給相應(yīng)的操作。
我們可以來看看這個案例,在我們輸出這個name
的時候,執(zhí)行的RHS查詢,負(fù)責(zé)獲取變量name
的值
codeconsole.log(name); // 在這個例子中,RHS查詢負(fù)責(zé)獲取變量name的值并傳遞給console.log
LHS和RHS查詢的細(xì)微差異
1. 查詢的方向與操作數(shù)
- 強調(diào)LHS查詢與RHS查詢的本質(zhì)區(qū)別在于操作數(shù)的方向,一個是賦值的左側(cè),一個是獲取值的右側(cè)。
- 通過比較LHS和RHS查詢在語法結(jié)構(gòu)中的不同,加深讀者對它們的理解。
我們通過下面這個案例來分析LHS和RHS直接的差異!
首先var x = 10
執(zhí)行的LHS查詢,找到x
的本身,并且把10賦值給x
在var y = x
這個語句當(dāng)中,同時存在LHS和RHS,為什么呢?
其中var y = 值
這里肯定執(zhí)行的LHS,負(fù)責(zé)找到y
本身,并且賦值
但是其中的值是x
是一個變量,所以又要進行RHS查詢獲取到x
的值!
var x = 10; var y = x; // 在這里,x的RHS查詢獲取值,y的LHS查詢分配內(nèi)存并初始化
2. 函數(shù)調(diào)用與查詢操作
- 分析函數(shù)調(diào)用中的LHS和RHS查詢,探討調(diào)用過程中參數(shù)的查詢操作。
- 通過例子展示函數(shù)調(diào)用背后的查詢細(xì)節(jié)。
來分析下面的案例:
- 引擎首先會創(chuàng)建一個變量
result
,它會在當(dāng)前作用域中進行 LHS 引用。 - 接著,引擎遇到
multiply(3, 4)
這個表達式,會進行 RHS 引用。它會在作用域中查找multiply
函數(shù)。 - 找到
multiply
函數(shù)后,引擎會創(chuàng)建一個新的執(zhí)行上下文(execution context)用于調(diào)用multiply
函數(shù)。這個執(zhí)行上下文會包含參數(shù)a
和b
,分別被賦值為3
和4
。 multiply
函數(shù)執(zhí)行,計算3 * 4
的結(jié)果,返回12
。- 返回到主程序,將
result
賦值為12
。
整個過程中,LHS 引用用于變量的賦值操作,RHS 引用用于變量值的檢索操作。在這個例子中,multiply(3, 4)
的 RHS 引用觸發(fā)了函數(shù)的調(diào)用,而 result
的 LHS 引用用于將函數(shù)調(diào)用的結(jié)果賦值給 result
。
function multiply(a, b) { return a * b; } var result = multiply(3, 4); // 函數(shù)調(diào)用中的LHS和RHS查詢,以及賦值操作
最后:
總結(jié)一句話就是:
RHS查詢負(fù)責(zé)找到這個變量的值,而LHS查詢則是為了找到變量的容器本身,然后將我們要給它賦的值裝進去(賦值)!
學(xué)習(xí)LHS和RHS查詢,能夠幫助我們理解JavaScript編譯的運行機制,還能夠幫助我們編寫更高效、更健壯的代碼。希望這篇文章能夠為大家提供一些學(xué)習(xí)理解LHS和RHS查詢的助力!
以上就是淺聊一下JavaScript中的LHS和RHS查詢的詳細(xì)內(nèi)容,更多關(guān)于JavaScript LHS和RHS查詢的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
BootStrap智能表單實戰(zhàn)系列(七)驗證的支持
這篇文章主要介紹了BootStrap智能表單實戰(zhàn)系列(七)驗證的支持 ,凡是涉及到用戶編輯信息然后保存的頁面,都涉及到一個數(shù)據(jù)是否符合要求的檢查,需要客服端和服務(wù)器端的校驗的問題,本文介紹非常詳細(xì),具有參考價值,需要的朋友可以參考下2016-06-06微信小程序?qū)崿F(xiàn)watch監(jiān)聽
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)watch監(jiān)聽,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06利用AJAX實現(xiàn)WordPress中的文章列表及評論的分頁功能
在文中列表頁方面利用AJAX制作滾動到底觸發(fā)翻頁的效果比較常見,而在評論加載時AJAX顯示正在加載也很常用,下面就來看一下如何利用AJAX實現(xiàn)WordPress中的文章列表及評論的分頁功能2016-05-05微信小程序如何在頁面跳轉(zhuǎn)時進行頁面導(dǎo)航
小程序能夠在不同的頁面進行跳轉(zhuǎn)切換,路由起到了至關(guān)重要的作用,下面這篇文章主要給大家介紹了關(guān)于微信小程序如何在頁面跳轉(zhuǎn)時進行頁面導(dǎo)航的相關(guān)資料,需要的朋友可以參考下2022-09-09通過js簡單實現(xiàn)將一個文本內(nèi)容轉(zhuǎn)譯成加密文本
將文本內(nèi)容轉(zhuǎn)譯成加密文本,在某些情況下還是比較實用的,下面通過js簡單實現(xiàn)下,感興趣的朋友不要錯過2013-10-10vue組件中watch props根據(jù)v-if動態(tài)判斷并掛載DOM的問題
這篇文章主要介紹了vue組件中watch props根據(jù)v-if動態(tài)判斷并掛載DOM的問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-05-05