您好,登錄后才能下訂單哦!
預解釋(變量提升):在當前的作用域中,JS代碼從上到下執行之前,瀏覽器會默認的先把所有帶var/function關鍵字的進行提前的聲明或者定義 對帶var變量的是提前聲明(declare) 對帶function關鍵字的是提前定義(聲明+定義)(defined)
->在預解釋階段,帶var關鍵字的只是提前的聲明,只有在JS從上到下執行的過程中才會進行定義賦值:
1 //->預解釋階段:告訴瀏覽器在當前的作用域中(window)有一個名字叫做num的變量:var num;2 console.log(num);//->undefined(只有聲明沒有定義的默認值是undefined)3 var num = 13;//->num=13;(定義:給變量賦值num=13)4 console.log(num);//->13
->在預解釋階段,帶function關鍵字的,聲明+定義兩部分都完成了:
1 //->預解釋階段:fn=xxxfff000(xxxfff000是一個內存地址)2 console.log(fn);//->函數本身 function fn() { console.log("ok"); }3 function fn() {4 console.log("ok"); 5 }//->3-5行代碼在預解釋階段已經聲明加定義了,以后代碼執行的時候在遇到也不會重新進行操作,直接跳過這幾行就可以了 6 console.log(fn);//->函數本身 function fn() { console.log("ok"); }
->預解釋只發生在當前的作用域中,開始的時候只對window作用域下帶var/function關鍵字的進行預解釋,而函數體中出現的帶var/function關鍵字的這些代碼此時還都是一堆字符串呢(沒有實際意義),所以開始的時候函數體中帶這些關鍵字的都不需要管 只有全局代碼執行到函數執行的時候,才會形成一個新的私有作用域,在新的私有作用域中:首先給函數的形參賦值,其次是私有作用域中的預解釋:把私有作用域中帶var和function關鍵字的進行提前的聲明或者定義,最后才是私有作用域中的代碼從上到下執行
1 //首先是window作用域下的預解釋:var n; var s; function fn=xxxfff000; 2 console.log(n,s);//n->undefined; s->undefined 3 var n = 9;//全局作用域下的n=9; 4 var s = "str1";//全局作用域下的s="str1"; 5 function fn() { 6 console.log(n,s);//n->undefined; (這個是fn私有作用域的n) s->str1; (這個是全局作用域的s) 7 n = 7;//定義私有作用域下的n=7; 8 s = "str2";//定義全局作用域下的s="str2"; 9 var n = 6;//定義私有作用域下的n=6;10 }11 fn();12 console.log(n,s);//此時輸出的都是全局作用域的: n->9; s->str2;
->作用域鏈的問題: 在私有作用域中,JS代碼從上到下執行,如果遇到了一個變量, 首先看是否是自己私有的變量,如果是私有的,那么我們接下來的所有操作(獲取值,修改值...)都是用的自己私有的,和外面沒有任何關系 如果不是自己私有的,則去當前作用域的上一級作用域中查找,如果上一級有,那么接下來操作的,都是在操作上級作用域中的變量;如果上級也沒有,則繼續向上查找,一直找到window為止 如果找到window還沒有?如果是 變量=值 相當于給window下增加一個屬性名和屬性值:如果是console.log(變量)獲取值,會報錯
->如何看變量是否為私有的: 首先看是否為形參 然后看是否在私有作用域中聲明過(看有沒有帶var) 兩者有其一,就是自己私有的變量;如果兩個都不是,就不是私有的,按照上述的作用域鏈原理來進行查找
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。