JavaScript 変数ホイスティングの詳細な紹介 (コード例)

不言
リリース: 2019-03-12 16:28:22
転載
2615 人が閲覧しました

この記事では、JavaScript の変数昇格について詳しく紹介 (コード例) しています。一定の参考値があります。困っている友人は参考にしてください。お役に立てれば幸いです。

はじめに

「変数のプロモーション」とは、変数と関数の宣言がコードの先頭に物理的に移動されることを意味しますが、これは正確ではありません。
実際には、コード内の変数および関数宣言の場所は移動されませんが、コンパイル段階でメモリ内に配置されます。

変数の宣言方法

var、let、const
上記のキーワードを指定せずに直接代入された変数は Windows 環境にマウントされます;

let a=9
const a=1
var a=6
c=5
ログイン後にコピー

関数の宣言メソッド

JavaScript で関数を宣言するには、関数宣言と関数式の 2 つの方法があります。

//函数声明
function say(){
    console.log('hello') 
}

//函数表达式
var say=function (){
    console.log('hello') 
}
ログイン後にコピー

ホイスティングの利点

JavaScript コード セグメントが実行される前に関数宣言をメモリに配置する利点の 1 つは、宣言する前に関数を使用できることです。

/*** 正确的方式:先声明函数,再调用函数 (最佳实践)*/
function catName(name) {
    console.log("我的猫名叫 " + name);
}
catName("Tigger");
/*以上代码的执行结果是: "我的猫名叫 Tigger"*/


/*** 不推荐的方式:先调用函数,再声明函数 */
catName("Chloe");
function catName(name) {
    console.log("我的猫名叫 " + name);
}
/*代码执行的结果是: "我的猫名叫 Chloe"*/
ログイン後にコピー

プロモーション ルール

var によって宣言された変数は、プロモーション中にのみ宣言され、値は割り当てられません。デフォルトは未定義です。キーワードなしで直接割り当てられた変数は昇格されません (demo1)

関数の昇格は関数本体と一緒に昇格され、実行されません; (deom2)

事前解析の順序は上から下です;(demo4)

関数の優先順位は変数よりも高く、関数の宣言は現在のスコープの先頭に進みます; (deom3)

変数は同じ名前を持ち、プロモーション中に再定義されません; 値は後で割り当てられます実行フェーズでは上記の割り当てが上書きされます。(demo4)

関数の名前が同じ場合、プロモーション中に後の関数が前の関数を上書きします。(demo5)

関数と変数は同じ名前を持ち、関数がプロモートされる場合、定義は繰り返されず、変数は関数を上書きしません。実行フェーズの後半で割り当てられた値が前の値を上書きします。

#関数式を使用した関数の宣言は、変数宣言の規則に従ってプロモートされます; (deom6)

関数が実行されると、関数内の変数宣言と関数宣言もプロモートされます。ルールに従って、上記のルールが昇格されます; (deom7)

let と const は存在​​しません; (demo9、demo10)

/**demo1**/
console.log('a=',a) //a=undefined
console.log('b=',b) // Uncaught ReferenceError: b is not defined
var a=1
b=6


/**deom2**/
console.log('a=',a)  // a=function  a() {console.log("func a()")}
function  a() {
console.log("func a()")
}

/**deom3**/
console.log('a=',a) // a=function  a() {console.log("fun a")}
var a=3
var a=4

function a(){
console.log("fun a")
}
var a=5
var a=6
console.log("a=",a) // a=6



/**deom4**/
console.log('a=',a)  // a=undefined
var a =2
console.log('a=',a) //
var a =3
var a =4
console.log('a=',a) // a=4
console.log('b=',b) //b= undefined
var b='b1'


/**deom5**/
console.log('a=',a) // a=function  a() {console.log("a2")}
function a(){
console.log("a1")
}
function a(){
console.log("a2")
}
console.log('a=',a) // a=function  a() {console.log("a2")}


/**deom6**/
console.log('a=',a) // a=undefined
var a=function(){console.log('a1')}
var a=3
var a=4
var a=5
console.log(a)
var a=function(){console.log('a2')}
console.log('a=',a) // a= ƒ (){console.log('a2')}


/**deom7**/
console.log('b=',b)
var a=3
function b(i){
    console.log('a=',a)
    var a=4
    function a(){
        console.log('fun a')
    }
    console.log('a=',a)
}
b()


/**demo8**/
console.log('a=',a) //a= function a(){ console.log('fun a')}
var a=2
function a(){
    console.log('fun a')
}
console.log('a=',a) // a=2
var a=3
var a=4
var a=5
console.log('a=',a) // a=5


/**demo9**/
console.log('a=',a) //Uncaught ReferenceError: a is not defined
let a=4


/****/
<!--demo10-->
console.log('b=',b) // Uncaught ReferenceError: b is not defined
const b=5
ログイン後にコピー

以上がJavaScript 変数ホイスティングの詳細な紹介 (コード例)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:segmentfault.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート