この記事では、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 サイトの他の関連記事を参照してください。