關(guān)于javascript作用域的常見面試題分享
本文主要給大家分享了關(guān)于javascript作用域面試題的相關(guān)內(nèi)容,分享出來供大家參考學習,下面來一起看看吧。
一、作用域:
在了解作用域之前,首先需要明白一些基礎(chǔ)概念:
每一個變量、函數(shù)都有其作用的范圍,超出作用不得使用,這個叫做作用域。
二、全局變量、局部變量:
1.全局變量:
(1)在全局范圍內(nèi)聲明的變量,如var a=1;
(2)只有賦值沒有聲明的值,如a=2;
(注:如果a=2在函數(shù)環(huán)境中,也是全局變量)
2.局部變量:
寫入函數(shù)中的變量,叫做局部變量。
3.作用:
(1)程序的安全。
(2)內(nèi)存的釋放。
三、作用域鏈:
查找量的過程。先找自己局部環(huán)境有沒有聲明或者是函數(shù),如果有,則查看聲明有無賦值或者是函數(shù)的內(nèi)容,如果沒有,則向上一級查找。
四、預(yù)解析順序:
每個程序都要做的工作,程序開始先預(yù)解析語法,標點符號是否有誤,解析內(nèi)存是否可容納,解析變量……直到解析無誤了,才開始按正常的流程順序走。試想一下,如果沒有預(yù)解析順序,直接按流程順序走,可能程序執(zhí)行到最后一個函數(shù),發(fā)現(xiàn)了語法錯誤,才開始報錯,那性能要有多差?。?br />
順序內(nèi)容:
1.文件內(nèi)引用的<script>塊依次解析,從上到下連成一片。
2.每個script塊內(nèi)部的var(注意:只解析變量名,不解析值,如var a=2;
將var a解析在環(huán)境的開頭,并不解析后面的值,只有當程序執(zhí)行到var a=2
這行時,才會給變量賦值),function解析到本塊的開頭。
3.依次解析每個環(huán)境,將var
,function
解析到環(huán)境的開頭。
五、應(yīng)用場景(一些常見的作用域相關(guān)的面試題):
var a="aa"; function test(){ alert(a);//undefined,函數(shù)執(zhí)行后,在函數(shù)環(huán)境內(nèi),var a會預(yù)解析,當彈出a時,首先先找本層環(huán)境內(nèi)有無聲明,發(fā)現(xiàn)有。但是代碼沒有執(zhí)行到賦值,所以結(jié)果是undefined。 var a="bb";//var a會預(yù)解析在函數(shù)開頭,執(zhí)行到這行才進行賦值 alert(a);//“bb” } test(); alert(a);//"aa" 找全局環(huán)境下的聲明,找到了var a="aa"
var a="aa"; function test(){ alert(a);//“aa”,函數(shù)執(zhí)行后,在函數(shù)環(huán)境內(nèi),沒有找到本層環(huán)境關(guān)于a的聲明,所以開始向上一層環(huán)境查找。 a="bb";//執(zhí)行到這行開始改變?nèi)謅的量 } test(); alert(a);//"bb" 全局環(huán)境的a在函數(shù)執(zhí)行時已經(jīng)被改變
function test(){ b();//函數(shù)b會被預(yù)解析,因此可以調(diào)用,執(zhí)行了輸出1; var a=1; function b(){ console.log(1); console.log(a);//undefined var a=2; } } test();
六、總結(jié):
要搞清楚一個變量的作用域,重點是搞清楚預(yù)解析順序,然后再判斷作用域的范圍,這些都是有套路可言:先找本層環(huán)境有無聲明,有的話,看是否進行了賦值;只有聲明沒有執(zhí)行賦值,就是undefined。沒有聲明也沒有賦值的話,就再向上一層查找,直到找到為止。如果所有的執(zhí)行環(huán)境都沒有找到,那么控制臺就會報錯變量找不到。
函數(shù)的話就更簡單了:找本層環(huán)境是否有預(yù)解析的函數(shù),有的話即可執(zhí)行。沒有的話還是向上查找。
好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
JavaScript實現(xiàn)電燈開關(guān)小案例
這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)電燈開關(guān)小案例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-03-03基于javascript實現(xiàn)動態(tài)時鐘效果
這篇文章主要為大家詳細介紹了基于javascript實現(xiàn)動態(tài)時鐘效果的相關(guān)資料,動態(tài)顯示系統(tǒng)當前時間,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-02-02Bootstrap 填充Json數(shù)據(jù)的實例代碼
本篇文章主要介紹了Bootstrap 填充Json數(shù)據(jù)的實例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01layui 圖片上傳+表單提交+ Spring MVC的實例
今天小編就為大家分享一篇layui 圖片上傳+表單提交+ Spring MVC的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09JavaScript比較當前時間是否在指定時間段內(nèi)的方法
這篇文章主要介紹了JavaScript比較當前時間是否在指定時間段內(nèi)的方法,涉及javascript時間與字符串的轉(zhuǎn)換及比較操作相關(guān)技巧,需要的朋友可以參考下2016-08-08