javascript变量晋升的具体介绍(代码示例)
本篇文章给大家带来的内容是关于javascript变量晋升的具体介绍(代码示例),有必然的参照 价值,有需要的伴侣可以参照 一下,但愿对你有所帮忙。
简介
“变量晋升”意味着变量和函数的声明会在物理层面移动到代码的最前面,但这么说并不准确。
实际上变量和函数声明在代码里的位置是不会动的,而是在编译阶段被放入内存中。
声明变量的办法
var、let、const
不消以上关键字直接赋值的变量会挂载与windows环境下;
let a=9 const a=1 var a=6 c=5
声明函数的办法
javascript中声明函数的办法有两种:函数声明式和函数表达式。
//函数声明 function say(){ console.log('hello') } //函数表达式 var say=function (){ console.log('hello') }
晋升的好处
JavaScript 在施行任何代码段此前,将函数声明放入内存中的长处之一是,这同意你可以在在声明该函数此前使用一个函数。
/*** 准确的方式:先声明函数,再调取函数 (最好实践)*/ function catName(name) { console.log("我的猫名叫 " + name); } catName("Tigger"); /*以上代码的施行结果是: "我的猫名叫 Tigger"*/ /*** 不引荐的方式:先调取函数,再声明函数 */ catName("Chloe"); function catName(name) { console.log("我的猫名叫 " + name); } /*代码施行的结果是: "我的猫名叫 Chloe"*/
晋升规则
var 声明的变量,晋升时只声明,不赋值,默许为undefined;不消关键字直接赋值的变量不存在晋升(demo1)
函数晋升会连带函数体一起晋升,不施行;(deom2)
预解析的次序是从上到下;(demo4)
函数的优先级高于变量,函数声明提早到当前作用域最顶端;(deom3)
变量重名,晋升时不会反复定义;在施行阶段后面赋值的会覆盖上面的赋值;(demo4)
函数重名,晋升时后面的会覆盖前面;(demo5)
函数和变量重名,晋升函数,不会反复定义,变量不会覆盖函数;在施行阶段后面赋值的会覆盖上面的赋值;(demo8)
用函数表达式声明函数,会依照声明变量规则停止晋升;(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变量晋升的具体介绍(代码示例)的具体内容,更多请关注百分百源码网其它相关文章!