亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

javascript 聲明前置與作用域 ( hoisting& Scoping)

mmy123456 / 2899人閱讀

摘要:特別注意的是不用聲明的變量那么他歸所有也就是全局作用域所有。如果到達(dá)全局作用域但是這個(gè)變量仍未找到,則會(huì)拋出異常。語(yǔ)句結(jié)束后,作用域鏈恢復(fù)正常。

1.javascript不管是變量(or 叫變量表達(dá)式?或者變量的聲明與賦值吧 var scope="loacal")的聲明還是函數(shù)(or 函數(shù)表達(dá)式)的聲明,都遵循命名在當(dāng)前作用域前置(提升到當(dāng)前命名空間頂端)函數(shù)體保留在原地。
var scope="global";//全局變量
function text(){
    console.log(scope);//輸出為undefined
    var scope="local";
    console.log(scope);//輸出為local
}
text();

而上面的代碼等價(jià)于

var scope;
scope="global"
function text(){
   var scope;         //命名前置
   console.log(scope);//輸出為undefined
   scope="local";
   console.log(scope);//輸出為local
}
text();

換成函數(shù)

text1();
function text1(){//函數(shù)的聲明
    alert(1);//彈出1
}
text2();
var text2=function(){//函數(shù)表達(dá)式
    alert(1);//undefined is not a function
}
//上面的函數(shù)表達(dá)式聲明等價(jià)于
var text3;//聲明前置
text3();
text3=function(){//函數(shù)體留在原地
    alert(1);
}
2.javascript只有函數(shù)級(jí)作用域沒(méi)有塊級(jí)作用域。
var name="golbar";
if(true){
    var name="local";
    console.log(name);//輸出local
}
console.log(name);//也輸出local

如果存在塊級(jí)作用域那么第一個(gè)值為local第二個(gè)值為golbar。
塊級(jí)作用域指的是能用for if while 等代碼塊形成的獨(dú)立作用域,即為塊級(jí)作用域。
特別注意的是不用var 聲明的變量那么他歸window所有也就是全局作用域所有。
每次引用一個(gè)變量,JavaScript 會(huì)向上遍歷整個(gè)作用域直到找到這個(gè)變量為止。如果到達(dá)全局作用域但是這個(gè)變量仍未找到,則會(huì)拋出 ReferenceError 異常。

function text(){
    log="in function";
    console.log(log);
};
text();
console.log(window.log)//都輸出為 in function

還有個(gè)就是作用域鏈:一個(gè)函數(shù)體重嵌套了多層函數(shù)體,并在不同的函數(shù)體中定義了同一個(gè)變量,當(dāng)其中一個(gè)函數(shù)訪問(wèn)這個(gè)變量時(shí),變會(huì)形成一條作用域鏈 scope chain

chain="window";
function one(){
    var chain="one";
    function two(){
        var chain="two";
        console.log(chain);
    };
    function three(){
        console.log(chain);
    };
    two();
    three();
};
one();             //two one 
console.log(chain);// window

作用域鏈有個(gè)特殊情況就是with語(yǔ)句:JS中的with語(yǔ)句主要用來(lái)臨時(shí)擴(kuò)展作用域鏈,將語(yǔ)句中的對(duì)象添加到作用域的頭部。with語(yǔ)句結(jié)束后,作用域鏈恢復(fù)正常。

chain="window";
function one(){
    var chain="one";
     function two(obj){
         console.log(chain);//輸出為one
         with(obj){
         console.log(chain)//輸出為obj
         }
     }
     var obj={chain:"obj"};
     two(obj);
}
one();   

還有就是編寫(xiě)代碼的時(shí)候雖然JS可以不用;或者相直接 if(true) return; 但盡量不要這樣寫(xiě)。至于為什么的話以后會(huì)寫(xiě)。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/86554.html

相關(guān)文章

  • [翻譯] JavaScript Scoping and Hoisting

    摘要:對(duì)于新手來(lái)說(shuō)是最令人困惑的部分之一。函數(shù)聲明通過(guò)的形式。很明顯的,語(yǔ)言自身定義和函數(shù)形參已經(jīng)處于作用域頂端。這就意味著,函數(shù)聲明比變量聲明具有更高的優(yōu)先級(jí)。但是這卻不意味著對(duì)這個(gè)名稱的賦值無(wú)效,僅僅是聲明的部分會(huì)被忽略而已。 原文鏈接:JavaScript Scoping and Hoisting 你知道下面的JavaScript代碼執(zhí)行后會(huì)alert出什么值嗎? var foo = ...

    FingerLiu 評(píng)論0 收藏0
  • 理解 JavaScript(二)

    摘要:所以形式參數(shù)是本地的,不是外部的或者全局的。這叫做函數(shù)聲明,函數(shù)聲明會(huì)連通命名和函數(shù)體一起被提升至作用域頂部。這叫做函數(shù)表達(dá)式,函數(shù)表達(dá)式只有命名會(huì)被提升,定義的函數(shù)體則不會(huì)。 Scoping & Hoisting var a = 1; function foo() { if (!a) { var a = 2; } alert(a); }; ...

    luxixing 評(píng)論0 收藏0
  • JS基礎(chǔ)篇--函數(shù)聲明定義,作用,函數(shù)聲明表達(dá)式的區(qū)別

    摘要:在中,有四種方式可以讓命名進(jìn)入到作用域中按優(yōu)先級(jí)語(yǔ)言定義的命名比如或者,它們?cè)谒凶饔糜騼?nèi)都有效且優(yōu)先級(jí)最高,所以在任何地方你都不能把變量命名為之類的,這樣是沒(méi)有意義的形式參數(shù)函數(shù)定義時(shí)聲明的形式參數(shù)會(huì)作為變量被至該函數(shù)的作用域內(nèi)。 Scoping & Hoisting 例: var a = 1; function foo() { if (!a) { var ...

    TerryCai 評(píng)論0 收藏0
  • JavaScript中的變量提升、作用

    摘要:即的變量提升此處變量未聲明時(shí)便可以使用,其實(shí)是因?yàn)闀?huì)自動(dòng)將聲明語(yǔ)句提升到頂部。但名字的初始化卻是按其在代碼中書(shū)寫(xiě)的順序進(jìn)行的,不受以上優(yōu)先級(jí)的影響。 變量提升(hoisting) 在JavaScript中,函數(shù)、變量的聲明都會(huì)被提升(hoisting)到該函數(shù)或變量所在的scope的頂部。即——JavaScript的變量提升. var x = 5; alert(x); ...

    wwq0327 評(píng)論0 收藏0
  • es6必會(huì)之let && const

    摘要:副作用,無(wú)副作用可執(zhí)行和關(guān)鍵詞。和不能像一樣同一個(gè)下聲明多次和不會(huì)像一樣變量聲明提升原因是,存在因此不能,賦值前使用變量。 showImg(https://segmentfault.com/img/bVbhPlD?w=1271&h=715); 關(guān)鍵詞: let ,const, blocking scope ,temporal dead zone,redeclaration,reassi...

    ygyooo 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<