详解 javascript 变量提升


prtyaa
prtyaa 2023-12-26 17:08:26 62861
分类专栏: 资讯

变量提升是在面试中常见被问到的问题,今天就来说一下这个问题。

一、概念

使用 var 来声明变量的时候,会提到当前作用域的顶端,赋值语句在原地等待赋值。

javascript 在执行的时候会分为两部分:

预编译阶段:js 在变量声明提升的时候,会将 var 声明的变量以及用关键字函数声明的函数都会提升到当前作用域的顶端,赋值语句在原地等待赋值。

这里要注意:如果变量名与函数相同的情况下,函数的优先级大于变量

执行阶段:自上而下执行

案例:

<body>
	<input type="button" id="btn" value="访问num" />
</body>

<script type="text/javascript">
	var btn = document.querySelector('#btn')
	btn.onclick = function(){ num = 10;
		alert(num)
	}
</script>
动图封面
 

这里可以看到先声明 num 后访问是可以访问到的

如果把 num 写到 alert 后面就会发生变量提升,就会显示 undefined 未赋值

<script type="text/javascript">
	var btn = document.querySelector('#btn')
	btn.onclick = function() {
		alert(num)
		var num = 10;
	}
</script>
动图封面
 

这段代码解析可以写为一下方式

num 发生变量提升,提升到当前作用域的顶端,赋值语句在原地等待赋值

<script type="text/javascript">
	var btn = document.querySelector('#btn')
	btn.onclick = function() {
		var num; //变量提升
		alert(num)
		num = 10; //赋值语句在原地等待赋值
	}
</script>

多个 script 的情况

<script type="text/javascript">
	console.log(num)
</script>
<script type="text/javascript">
	var num = 10;
</script>

这里控制台就会报错,num 没有定义

Uncaught ReferenceError: num is not defined

变量提升不能跨 script

二、关键字函数提升

<script type="text/javascript">
	var btn = document.querySelector('#btn')
	btn.onclick = function() {
		var fn = 10;
		var fn = function(){}
		alert(fn)
	}
</script>
动图封面
 

这里出来的就是函数体,函数的优先级大于变量,先提升。

网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。

本文链接:https://www.xckfsq.com/news/show.html?id=30900
赞同 0
评论 0 条
prtyaaL0
粉丝 1 发表 2554 + 关注 私信
上周热门
银河麒麟添加网络打印机时,出现“client-error-not-possible”错误提示  1323
银河麒麟打印带有图像的文档时出错  1236
银河麒麟添加打印机时,出现“server-error-internal-error”  1023
统信桌面专业版【如何查询系统安装时间】  951
统信操作系统各版本介绍  944
统信桌面专业版【全盘安装UOS系统】介绍  903
麒麟系统也能完整体验微信啦!  889
统信【启动盘制作工具】使用介绍  499
统信桌面专业版【一个U盘做多个系统启动盘】的方法  441
信刻全自动档案蓝光光盘检测一体机  386
本周热议
我的信创开放社区兼职赚钱历程 40
今天你签到了吗? 27
信创开放社区邀请他人注册的具体步骤如下 15
如何玩转信创开放社区—从小白进阶到专家 15
方德桌面操作系统 14
我有15积分有什么用? 13
用抖音玩法闯信创开放社区——用平台宣传企业产品服务 13
如何让你先人一步获得悬赏问题信息?(创作者必看) 12
2024中国信创产业发展大会暨中国信息科技创新与应用博览会 9
中央国家机关政府采购中心:应当将CPU、操作系统符合安全可靠测评要求纳入采购需求 8

添加我为好友,拉您入交流群!

请使用微信扫一扫!