简介
“变量提升”意味着变量和函数的声明会在物理层面移动到代码的最前面,但这么说并不准确。
实际上变量和函数声明在代码里的位置是不会动的,而是在编译阶段被放入内存中。
声明变量的方法
var、let、const
不用以上关键字直接赋值的变量会挂载与windows环境下;
let a=9const a=1var a=6c=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"*/
提升规则
/**demo1**/console.log('a=',a) //a=undefinedconsole.log('b=',b) // Uncaught ReferenceError: b is not definedvar a=1b=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=3var a=4function a(){console.log("fun a")}var a=5var a=6console.log("a=",a) // a=6 /**deom4**/console.log('a=',a) // a=undefinedvar a =2console.log('a=',a) //var a =3var a =4console.log('a=',a) // a=4console.log('b=',b) //b= undefinedvar 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=undefinedvar a=function(){console.log('a1')}var a=3var a=4var a=5console.log(a)var a=function(){console.log('a2')}console.log('a=',a) // a= ƒ (){console.log('a2')}/**deom7**/console.log('b=',b)var a=3function 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=2function a(){ console.log('fun a')}console.log('a=',a) // a=2var a=3var a=4var a=5console.log('a=',a) // a=5/**demo9**/console.log('a=',a) //Uncaught ReferenceError: a is not definedlet a=4/****/<!--demo10-->console.log('b=',b) // Uncaught ReferenceError: b is not definedconst b=5
参考资料
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。
新闻热点
疑难解答