变量和函数提升

本文详细阐述了JavaScript中的变量和函数提升现象。变量提升使得使用`var`声明的变量在代码执行前被声明,但未赋值,表现为`undefined`;非`var`声明的变量则不会提升。函数声明形式的函数会提升,而函数表达式不会。函数提升优先于变量提升,且变量赋值会覆盖函数提升。
摘要由CSDN通过智能技术生成
变量和函数提升
变量声明提升

使用var关键字声明的变量,会在所有的代码执行之前被声明但不会被赋值,在定义域之前就能访问到,只不过是undefined,但是如果声明变量时不是var关键字,则变量不会被声明提前。

<script>
console.log(a)//undefined
var a=10
</script>

变量提升后,这个代码就相当于

<script>
var a
console.log(window.a)
a=10
</script>

如果是以下代码就会报错

<script>
console.log(a)//因为这里就是没有var声明,变量不会提升导致报错,
a=10
</script>
函数声明提升
<script>
    fun()//正常打印输出
	fun2()//报错,undefined is not a function
function fun(){
    console.log("我是一个fun函数")
}
var fun2=function (){
      console.log("我是一个fun2函数")
}
    
 </script>

这是因为使用函数声明形式创建的函数function 函数( ){} ,它会在所有的代码执行之前就被创建,即他的代码相当于

<script>
function fun(){
    console.log("我是一个fun函数")
}//函数声明提升,永远在最前面
 fun()
</script>

而使用函数表达式创建的函数,不会被声明提前(变量赋值会覆盖函数提升),所以不能在声明前调用,即fun2函数的代码相当于

<script>
	var fun2
	console.log(fun2)//此时打印的结果是undefined
	fun2()//那么这个地方调用肯定会报错undefined is not a function
	fun2=function (){
      console.log("我是一个fun2函数")
    }
</script>

3.函数先提升,变量后提升,变量提升不会覆盖函数提升,变量赋值会覆盖函数提升

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值