JS变量提升及函数提升实例解析


Posted in Javascript onSeptember 03, 2020

1在js中只有两种作用域

a:全局作用域

b:函数作用域

在ES6之前,js是没有块级作用域。

首先来解释一下什么是没有块级作用域?

JS变量提升及函数提升实例解析

所以此时 是可以打印输出变量a的值。

2:什么是变量提升?

在我们的js中,代码的执行时分两步走的,1、预解析 2、一步一步执行

在预解析阶段:首先会在全局作用域内,js解析器会找所有的 var 、function 、参数,并提前到当前作用域的最顶上去(变量的赋值操作不会提前,还在原来的地方),此时并没有执行代码。

然后再开始一行一行执行代码。遇到了函数调用,于是进入到函数作用域内,又开始分两步骤走,1、预解析 2、一步一步执行。以此类推。

那么变量提升就是变量声明会被提升到作用域的最顶上去,也就是该变量不管是在作用域的哪个地方声明的,都会提升到作作用域的最顶上去。

即变量可以在声明之前使用,值为undefined。

JS变量提升及函数提升实例解析

那么上面这种写法其实等价于下面这种写法:

JS变量提升及函数提升实例解析

看几个例子:

JS变量提升及函数提升实例解析

把上面的例子稍作改动:

结果就会大不一样,

JS变量提升及函数提升实例解析

再看一个例子:

JS变量提升及函数提升实例解析

3:什么是函数提升?

JS变量提升及函数提升实例解析

输出的结果是:

JS变量提升及函数提升实例解析

注意:函数声明式,会将函数的声明和定义一起提升到作用域的最顶上去。

如果是这种写法:函数表达式声明的函数

JS变量提升及函数提升实例解析

例子:

JS变量提升及函数提升实例解析

输出的结果是:

JS变量提升及函数提升实例解析

最后的总结:

1:所有的声明都会提升到作用域的最顶上去。

2:同一个变量只会声明一次,其他的会被忽略掉。

3:函数声明的优先级高于变量申明的优先级,并且函数声明和函数定义的部分一起被提升。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Mootools 1.2教程 滑动效果(Slide)
Sep 15 Javascript
js如何实现点击标签文字,文字在文本框出现
Aug 05 Javascript
浅谈使用MVC模式进行JavaScript程序开发
Nov 10 Javascript
js仿支付宝填写支付密码效果实现多方框输入密码
Mar 09 Javascript
BootStrap表单验证实例代码
Jan 13 Javascript
从零学习node.js之搭建http服务器(二)
Feb 21 Javascript
JavaScript表单验证完美代码
Mar 02 Javascript
微信小程序踩坑记录之解决tabBar.list[3].selectedIconPath大小超过40kb
Jul 04 Javascript
JavaScript实现浅拷贝与深拷贝的方法分析
Jul 05 Javascript
使用rollup打包JS的方法步骤
Dec 05 Javascript
bootstrap Table实现合并相同行
Jul 19 Javascript
js计时事件实现圆形时钟
Mar 25 Javascript
Vue自定义组件双向绑定实现原理及方法详解
Sep 03 #Javascript
Vue js with语句原理及用法解析
Sep 03 #Javascript
Vue通过provide inject实现组件通信
Sep 03 #Javascript
Vue组件通信$attrs、$listeners实现原理解析
Sep 03 #Javascript
Vue父组件监听子组件生命周期
Sep 03 #Javascript
JavaScript 几种循环方式以及模块化的总结
Sep 03 #Javascript
Vuejs通过拖动改变元素宽度实现自适应
Sep 02 #Javascript
You might like
PHP中的日期处理方法集锦
2007/01/02 PHP
PHP+javascript制作带提示的验证码源码分享
2014/05/28 PHP
Symfony2使用Doctrine进行数据库查询方法实例总结
2016/03/18 PHP
PHP操作Postgresql封装类与应用完整实例
2018/04/24 PHP
javascript 操作符(~、&、|、^、)使用案例
2014/12/31 Javascript
jQuery前端分页示例分享
2015/02/10 Javascript
简单介绍JavaScript的变量和数据类型
2015/06/03 Javascript
JavaScript实现自动消除按钮功能的方法
2015/08/05 Javascript
跟我学习javascript的全局变量
2015/11/16 Javascript
javascript中eval解析JSON字符串
2016/02/27 Javascript
9种改善AngularJS性能的方法
2017/11/28 Javascript
vue技术分享之你可能不知道的7个秘密
2018/04/09 Javascript
微信小程序实现弹出层效果
2020/05/26 Javascript
JS实现图片拖拽交换效果
2018/11/30 Javascript
[01:55]2014DOTA2国际邀请赛快报:国土生病 紧急去医院治疗
2014/07/10 DOTA
[02:57]2014DOTA2国际邀请赛-观众采访
2014/07/19 DOTA
在Python中使用HTMLParser解析HTML的教程
2015/04/29 Python
详谈Python中列表list,元祖tuple和numpy中的array区别
2018/04/18 Python
python使用folium库绘制地图点击框
2018/09/21 Python
Python和Java的语法对比分析语法简洁上python的确完美胜出
2019/05/10 Python
pytorch打印网络结构的实例
2019/08/19 Python
python小项目之五子棋游戏
2019/12/26 Python
pytorch加载自定义网络权重的实现
2020/01/07 Python
python获取时间戳的实现示例(10位和13位)
2020/09/23 Python
工程师必须了解的LRU缓存淘汰算法以及python实现过程
2020/10/15 Python
html2canvas生成的图片偏移不完整的解决方法
2020/05/19 HTML / CSS
美国顶级户外凉鞋品牌:Chacos
2017/03/27 全球购物
美国健康和保健平台:healtop
2020/07/02 全球购物
建筑专业自我鉴定
2013/10/22 职场文书
中专生自我鉴定范文
2014/02/02 职场文书
网络工程师职业规划
2014/02/10 职场文书
2014年健康教育实施方案
2014/02/17 职场文书
《棉鞋里的阳光》教学反思
2014/04/24 职场文书
党委班子对照检查材料
2014/08/19 职场文书
酒店温馨提示语
2015/07/14 职场文书
MySQL池化框架学习接池自定义
2022/07/23 MySQL