百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>JS教程> javascript变量晋升的具体介绍(代码示例)
分享文章到:

javascript变量晋升的具体介绍(代码示例)

发布时间:09/01 来源:未知 浏览: 关键词:

本篇文章给大家带来的内容是关于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变量晋升的具体介绍(代码示例)的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板