摘要:,在這里的將所有的函數(shù)聲明進(jìn)行了提升,從而由替代了函數(shù)表達(dá)式的在順著條件判斷進(jìn)行了定義,執(zhí)行為的情況,進(jìn)行賦值解析。
函數(shù)聲明(funDeclaration)
無論在哪兒定義函數(shù),只要是外層函數(shù)并且滿足不被包裹,就都可以進(jìn)行全局范圍的調(diào)用
function foo() { }
在函數(shù)體內(nèi)部的函數(shù)聲明無法提升到全局,只能提升到函數(shù)體內(nèi)頂部(塊級作用域空間)
function test() { console.log(1); function test2() { console.log(2); } } test(); // 1 test2(); // Uncaught ReferenceError: test2 is not defined
函數(shù)體內(nèi)部執(zhí)行:
function test() { test2(); function test2() { console.log(2); } } test(); // 2
在外部要想訪問函數(shù)內(nèi)部申明的函數(shù),需要先return出來:
function test() { console.log(1); function test2() { console.log(2); } return { test2:test2 } } test().test2(); // 2函數(shù)表達(dá)式(funExpression)
函數(shù)表達(dá)式需要等到表達(dá)式賦值 完成 才可以
換言之使用var來聲明函數(shù),就會涉及到變量的聲明提升,先拿出變量名定義為undefined,再隨著邏輯順序進(jìn)行賦值先定義,后使用
var foo = function () { }demo1
Toast() // hello world showToast(); // shwoToast is not a function var showToast = function () { console.log("123") } function Toast() { console.log("hello world") }
在這里只需要把showToast 提前就好了demo2 主流瀏覽器解析,ie11+
var sayHello; console.log(typeof (sayHey));//=>undefined console.log(typeof (sayHo));//=>undefined if (true) { function sayHey() { console.log("sayHey"); } sayHello = function sayHo() { console.log("sayHello"); } } else { function sayHey() { console.log("sayHey2"); } sayHello = function sayHo() { console.log("sayHello2"); } } sayHey();// => sayHey sayHello();// => sayHello
在花括號里面聲明的函數(shù)在進(jìn)行預(yù)解析時只會提升函數(shù)名,不會提升函數(shù)體,所以不管if條件是否為真,函數(shù)體都不會提升,永遠(yuǎn)是undefined,接下來隨著if條件判斷進(jìn)行解析賦值,當(dāng)然是走ture方法。
ie9,ie10var sayHello; console.log(typeof (sayHey));//=>function console.log(typeof (sayHo));//=>undefined if (true) { function sayHey() { console.log("sayHey"); } sayHello = function sayHo() { console.log("sayHello"); } } else { function sayHey() { console.log("sayHey2"); } sayHello = function sayHo() { console.log("sayHello2"); } } sayHey();// => sayHey2 sayHello();// => sayHello
在這里的ie將所有的函數(shù)聲明進(jìn)行了提升,從而由sayHey2替代了sayHey,函數(shù)表達(dá)式的在順著條件判斷進(jìn)行了定義,執(zhí)行為true的情況,進(jìn)行賦值解析。
ie8var sayHello; console.log(typeof (sayHey));//=>function console.log(typeof (sayHello));//=>function if (true) { function sayHey() { console.log("sayHey"); } sayHello = function sayHo() { console.log("sayHello"); } } else { function sayHey() { console.log("sayHey2"); } sayHello = function sayHo() { console.log("sayHello2"); } } sayHey();// => sayHey2 sayHello();// => sayHello
ie8在這里處理的比較奇葩,正常的函數(shù)申明提升,但是卻也將條件判斷為假的情況進(jìn)行了提升,我們看到typeof (sayHello)=>function
結(jié)論由于函數(shù)聲明提升的差異,想要在條件判斷中定義不同的函數(shù)方法,應(yīng)該采用定義函數(shù)表達(dá)式的方法,這樣就在各個瀏覽器中拿到相同的函數(shù)方法,得到相同的結(jié)果。
var sayHello; console.log(typeof (sayHey));//=>undefined ie8以下解析為function console.log(typeof (sayHo));//=>undefined if (true) { var sayHey =function sayHey() { console.log("sayHey"); } } else { var sayHey =function sayHey() { console.log("sayHey2"); } } sayHey();// => sayHey
http://www.cnblogs.com/isaboy...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.hztianpu.com/yun/93786.html
摘要:在中,有四種方式可以讓命名進(jìn)入到作用域中按優(yōu)先級語言定義的命名比如或者,它們在所有作用域內(nèi)都有效且優(yōu)先級最高,所以在任何地方你都不能把變量命名為之類的,這樣是沒有意義的形式參數(shù)函數(shù)定義時聲明的形式參數(shù)會作為變量被至該函數(shù)的作用域內(nèi)。 Scoping & Hoisting 例: var a = 1; function foo() { if (!a) { var ...
摘要:有兩種定義函數(shù)的方式函數(shù)聲明與函數(shù)表達(dá)式。所以在實際開發(fā)的時候,一定要注意變量函數(shù)的聲明會被提升到當(dāng)前作用域的最前面 JS有兩種定義函數(shù)的方式:函數(shù)聲明與函數(shù)表達(dá)式。那么這兩種方式有區(qū)別嗎,還是一樣的呢?下面我們來進(jìn)一步探討探討。 下面我們定義了兩個函數(shù)分別為 hello 和 hi,前者采用函數(shù)聲明,后者采用函數(shù)表達(dá)式,然后再調(diào)用,如下: function hello () { ...
摘要:函數(shù)聲明和函數(shù)表達(dá)式的區(qū)別函數(shù)聲明只能出現(xiàn)在程序或函數(shù)體內(nèi)。所以,在等語義為語句的代碼塊中存在函數(shù)聲明,由于函數(shù)提升特性,會破壞掉原本的語義。 這篇談一下JS函數(shù)聲明與函數(shù)表達(dá)式的區(qū)別及要注意的地方: 函數(shù)聲明主要有兩種類型: 函數(shù)聲明 function fn() {}; 函數(shù)表達(dá)式 var fn = function () {}; 這兩種函數(shù)創(chuàng)建方式...
摘要:函數(shù)聲明函數(shù)聲明的語法說明函數(shù)聲明最重要的特征就是函數(shù)聲明提升,意思是在執(zhí)行代碼之前就會讀取函數(shù)聲明例子不會報錯,因為函數(shù)聲明在在函數(shù)之前已經(jīng)讀取函數(shù)表達(dá)式函數(shù)表達(dá)式的語法說明用函數(shù)表達(dá)式定義的函數(shù)在使用之前必須先賦值例子報錯,函數(shù)調(diào)用之前 1.函數(shù)聲明 函數(shù)聲明的語法: function functionName(arg0,arg1...) { //functionBody ...
摘要:最近在寫代碼時遇到了閉包,其中閉包又和立即執(zhí)行函數(shù)有點關(guān)系,于是牽扯除了函數(shù)聲明以及函數(shù)表達(dá)式,我感覺中文的很多文章寫的不太好,查閱了的指南和這篇關(guān)于的文章,覺得寫的很好,整合一下。函數(shù)聲明和函數(shù)表達(dá)式。 最近在寫代碼時遇到了閉包,其中閉包又和立即執(zhí)行函數(shù)(immediately invoked function expression, aka IIFE)有點關(guān)系,于是牽扯除了函數(shù)聲明...
閱讀 1392·2021-10-11 10:57
閱讀 2117·2021-09-02 15:15
閱讀 1713·2019-08-30 15:56
閱讀 1264·2019-08-30 15:55
閱讀 1217·2019-08-30 15:44
閱讀 1038·2019-08-29 12:20
閱讀 1414·2019-08-29 11:12
閱讀 1131·2019-08-28 18:29