javascript
JavaScript中变量提升是什么?如何实现?
在進行web前端開發的時候,我們經常會遇到變量提升的情況,那么JS在解析變量的時候是如何做到提升的呢?今天小千就來帶大家了解一下。
首先在JS中涉及兩種作用域的問題,那么什么是作用域呢?
作用域是代碼中所使用名字的作用范圍,分為Script全局作用域和函數局部作用域。 當瀏覽器在解析網頁內容時,會分別啟動不同的解析器來解釋代碼的含義,如解析標簽(超文本)的解析器、解析CSS樣式的解析器,解析javascript腳本的解析器。且解析過程為同步(按順序)解析。所以當瀏覽器解析到script標簽時,會停止對html和css的解析,同時啟動javascript的解析器。而在解析javascript的過程中我們主要關注解析器中的兩個步驟:
1.預解析,即在當前作用范圍中去尋找var、function、形參這三個內容。
如果找到var關鍵字、則提取var后面的名字放到當前作用域中,且默認給這個變量初始化一個值為undefined。
如果找到function關鍵字,則提取函數名放到當前作用域中,且將整個函數塊賦值給函數名。
如果找到形參,則將形參名放到當前作用域中,且默認初始化為undefined。這個過程也稱為變量提升。
2.逐行解讀代碼(即從上到下依次執行每一條語句)且分為兩個步驟:執行表達式和函數調用。
當變量名與函數名相同時:
當有多個script標簽時: - 多個script標簽時,從上到下依次解析script作用域,所以建議將所有聲明的語句放到第一個script中。
以上就是關于JS變量提升的介紹了,希望能幫到大家。最后歡迎對web前端開發感興趣的同學關注小千,后期繼續為大家分享更多web前端技術知識。
本文來自千鋒教育,轉載請注明出處。
總結
以上是生活随笔為你收集整理的JavaScript中变量提升是什么?如何实现?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 高阶前端开发人员必备工具-Node.JS
- 下一篇: HTML、CSS、JavaScript能