js 变量和函数声明提升

本文讲述了JavaScript中的变量提升现象,强调var声明的变量会被提升到作用域顶部,而let和const则不存在提升。同时介绍了函数声明的提升,以及如何避免因变量提升引发的bug,特别是对于ES6中块级作用域和函数表达式的区别进行了解释。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

变量提升是javascript中比较'奇怪'现象,它允许在变量声明之前被访问(仅存var声明变量)

注意:

1、变量在 未声明被访问时会报语法错误

2、变量var声明之前被访问,变量的值是undefined

3、let、const声明变量不存在变量声明提升

4、变量提升出现在相同作用域中

5、实际开发中推荐先声明在访问变量

<script>

console.log(arr);//undefined

var arr=[1,2,3]

console.log(str)//报错

let str='123456';

</script>

说明:

js初学者经常花很长事件才能习惯变量提升,还经常出现一些意想不到的bug,正因为如此,Es6引入了块级作用域,用let或者const声明变量,让代码写法更加规范和人性化。

用关键字var才存在变量声明提升。

变量声明提升的流程:

先把var变量提升到当前作用域最前面

只提升变量声明,不提升变量的值

然后依次执行代码

const和let不存在变量提升

函数声明提升

1、会把所有函数声明提升到当前作用域最前面

2、只提升函数声明,提升函数调用

<script>

fn()

function fn(){

console.log(111)

}

fn2()

var fn2=function (){

console.log(22)

}

//函数表达式,必须先声明和赋值,后调用,否则报错

</script>

总结:

1、函数提升能够使函数的声明调用更灵活

2、函数表达式不存在提升

3、函数提升出现在相同作用域当中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值