国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

函數聲明和聲明變量同時存在,提升的規則是什么?

dockerclub / 508人閱讀

摘要:若輸出為則證明函數聲明位于變量聲明之前若為說明相反。根據實驗結果,我們最后得出的排序結果是總結和反思函數聲明會提升到變量聲明之前。正確結論是優先級比高,無論在其前后,都會覆蓋掉同名的聲明。

這是一道新鮮的剛剛出爐的題目,目前只有2個回答,處于未解決狀態。
題目鏈接在這:https://segmentfault.com/q/10...
好奇心爆棚的我聽著電音思考了一發,應該沒錯吧。

var a=1;
foo();
function foo(){};

首先,我們可以把它分為4塊內容

var a ;
a =1;
foo();
function foo();

我們想知道提升后排序是什么形式?
目前已知條件是,變量聲明會提升到變量賦值之前,所以我們可以先將變量聲明放到前兩位,暫時不管其內部順序:

var a ;
function foo(){};
a=1;
foo();

接下來我們來分別確定聲明和賦值模塊的內部排序。
為了進行實驗,我們對foo函數進行擴充,所以現在的排序為:

var a;
function foo(){console.log(a+1)};
a=1;
foo();

先不要管為什么這么改,我們繼續實驗,實驗過程中會理解。
為了便于理解,實驗分兩次進行。
首先:我們對變量聲明模塊進行實驗。

var a=1;
console.log(foo);//若輸出為function foo(){}則證明函數聲明位于變量聲明之前;若為undefined,說明相反。
foo();
function foo(){console.log(a+1)};

然后:我們對變量賦值模塊進行實驗。

var a=1;
foo();//若輸出為undefined1,則證明foo()在a=1之前;若輸出為2,則說明a=1在foo()之前。
function foo(){console.log(a+1)};

下面來進行實驗:

var a=1;
console.log(foo);//若輸出為function foo(){}則證明函數聲明位于變量聲明之前;若為undefined,說明相反。
foo();
function foo(){console.log(a+1)};

VM1099:2 function foo(){console.log(a+1)}
VM1099:4 2

根據實驗結果,我們最后得出的排序結果是:

function foo(){};
var a;
a=1;
foo();

總結和反思:

1.函數聲明會提升到變量聲明之前。

2.提升只針對的是聲明部分,即出現var funtion等的地方,后續的賦值和函數調用按照當前默認順序依次執行。
前端菜鳥一只,若有不對的地方請及時指正!
期待與您交流!

------更新------2018.5.22------
結論是錯誤的,原因是console.log()是異步函數,導致實驗結果不準確。
正確結論是:function優先級比var高,無論在其前后,都會覆蓋掉同名的var聲明。

console.log(typeof foo);
var foo = "foo";
function foo(){}

輸出:function

console.log(typeof foo);
function foo(){}
var foo = "foo";

輸出:function

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/83015.html

相關文章

  • 譯:用let const 來指導JavaScript 變量提升

    摘要:最近在上看到一篇關于變量提升的文章,原文在此。對于剛入門的開發者時常難以理解變量方法提升的獨特行為。接下來我們要談論,,聲明,那么先了解變量提升就顯得更為重要了。在進入作用域和不能訪問的這段時間,我們稱為暫時性死區。 showImg(https://segmentfault.com/img/bV0Nsd?w=800&h=450); 最近在Medium上看到一篇關于變量提升的文章,原文在...

    sanyang 評論0 收藏0
  • 弄懂JavaScript作用域閉包

    摘要:關于本書,我會寫好幾篇讀書筆記用以記錄那些讓我恍然大悟的瞬間,本文是第一篇弄懂的作用域和閉包。作用域也可以看做是一套依據名稱查找變量的規則。聲明實際上是根據你傳遞給它的對象憑空創建了一個全新的詞法作用域。 《你不知道的JavaScript》真的是一本好書,閱讀這本書,我有多次哦,原來是這樣的感覺,以前自以為理解了(其實并非真的理解)的概念,這一次真的理解得更加透徹了。關于本書,我會寫好...

    everfly 評論0 收藏0
  • ES6學習 第一章 let const 命令

    摘要:外層作用域不報錯正常輸出塊級作用域與函數聲明規定,函數只能在頂層作用域和函數作用域之中聲明,不能在塊級作用域聲明。規定,塊級作用域之中,函數聲明語句的行為類似于,在塊級作用域之外不可引用。同時,函數聲明還會提升到所在的塊級作用域的頭部。 前言:最近開始看阮一峰老師的《ECMAScript 6 入門》(以下簡稱原...

    番茄西紅柿 評論0 收藏2637
  • ES5ES6作用域詳解

    摘要:允許在塊級作用域內聲明函數。上面代碼中,存在全局變量,但是塊級作用域內又聲明了一個局部變量,導致后者綁定這個塊級作用域,所以在聲明變量前,對賦值會報錯。 ES5的作用域 變量起作用的范圍,js中能創建作用域的只能是函數 { let a = 1; var b = 2; } console.log(a); // a is not defined console.log(b); //...

    Dr_Noooo 評論0 收藏0
  • ES2015系列--塊級作用域

    摘要:在的閉包中,閉包函數能夠訪問到包庇函數中的變量,這些閉包函數能夠訪問到的變量也因此被稱為自由變量。在之前最常見的兩種作用域,全局作用局和函數作用域局部作用域。 關于文章討論請訪問:https://github.com/Jocs/jocs.... 當Brendan Eich在1995年設計JavaScript第一個版本的時候,考慮的不是很周到,以至于最初版本的JavaScript有很多不...

    darkbug 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<