JavaScript之作用域,作用域鏈和預(yù)解析

2018-8-2    seo達人

如果您想訂閱本博客內(nèi)容,每天自動發(fā)到您的郵箱中, 請點這里

變量包括:全局變量,局部變量

在JAvaScript中,函數(shù)中定義的變量是局部變量

作用域:就是變量的使用范圍,

分為:局部作用域和全局作用域

js中沒有塊級作用域---一對括號中定義的變量,這個變量可以在大括號外面使用

作用域鏈:變量的使用,從里向外,層層的搜索,搜索到了就可以直接使用了


    
  1. var num=10; //作用域鏈 級別:0
  2. var num2=20;
  3. var str = "abc"
  4. function f1() {
  5. var num2=20;
  6. function f2() {
  7. var num3=30;
  8. console.log(num);
  9. }
  10. f2();
  11. }
  12. f1();

 層層搜索,搜索到0級作用域的時候,如果還是沒有找到這個變量,結(jié)果就是報錯

預(yù)解析:就是在瀏覽器解析代碼之前,把變量的聲明和函數(shù)的聲明提前(提升)到該作用域的最上面

(1)變量的提升

下面這種情況,變量的聲明被提前了,但是num的值并沒有提前,結(jié)果為undefined


    
  1. //變量的提升
  2. console.log(num);
  3. var num=100;
  4. //提升之后為:
  5. var num;//變量的聲明提前
  6. console.log(num);
  7. var num=100;

 (2)

函數(shù)聲明被提前,代碼仍然可以執(zhí)行


    
  1. //函數(shù)的聲明被提前了
  2. f1();
  3. function f1() {
  4. console.log("這個函數(shù),執(zhí)行了");
  5. }

但是對于下面這種情況,代碼報錯


    
  1. f2();
  2. var f2=function () {
  3. console.log("小楊好帥哦");
  4. }
  5. //聲明提前后:
  6. var f2;//為一個變量,undefind
  7. f2();//undefind加括號是不被認可的,所以報錯
  8. var f2=function () {
  9. console.log("小楊好帥哦");
  10. }

 要想不報錯,代碼可以改為:


    
  1. var f2;
  2. f2=function () {
  3. console.log("小楊好帥哦");
  4. };
  5. f2();

 藍藍設(shè)計www.bouu.cn )是一家專注而深入的界面設(shè)計公司,為期望卓越的國內(nèi)外企業(yè)提供卓越的UI界面設(shè)計、BS界面設(shè)計 、 cs界面設(shè)計 、 ipad界面設(shè)計 、 包裝設(shè)計 、 圖標定制 、 用戶體驗 、交互設(shè)計、 網(wǎng)站建設(shè) 、平面設(shè)計服務(wù)


分享本文至:

日歷

鏈接

個人資料

藍藍設(shè)計的小編 http://www.bouu.cn

存檔