详解javascript中的变量提升和函数提升


Posted in Javascript onMay 24, 2018

1在js中只有两种作用域

a:全局作用域

b:函数作用域

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

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

详解javascript中的变量提升和函数提升

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

2:什么是变量提升?

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

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

详解javascript中的变量提升和函数提升

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

详解javascript中的变量提升和函数提升

看几个例子:

详解javascript中的变量提升和函数提升

把上面的例子稍作改动:

结果就会大不一样,

详解javascript中的变量提升和函数提升

再看一个例子:

详解javascript中的变量提升和函数提升

3:什么是函数提升?

详解javascript中的变量提升和函数提升

输出的结果是:

详解javascript中的变量提升和函数提升

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

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

详解javascript中的变量提升和函数提升

例子:

详解javascript中的变量提升和函数提升

输出的结果是:

详解javascript中的变量提升和函数提升

最后的总结:

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

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

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

Javascript 相关文章推荐
xml 封装与解析(javascript和C#中)
Jul 26 Javascript
js 获取元素下面所有li的两种方法
Apr 14 Javascript
js兼容火狐显示上传图片预览效果的方法
May 21 Javascript
JavaScript中自带的 reduce()方法使用示例详解
Aug 10 Javascript
JS控制页面跳转时未请求要跳转的地址怎么回事
Oct 14 Javascript
微信小程序 常见问题总结(4058,40013)及解决办法
Jan 11 Javascript
Angular指令封装jQuery日期时间插件datetimepicker实现双向绑定示例
Jan 22 Javascript
浅谈Javascript事件对象
Feb 05 Javascript
Angular动态添加、删除输入框并计算值实例代码
Mar 29 Javascript
解决百度Echarts图表坐标轴越界的方法
Oct 17 Javascript
vue-cli随机生成port源码的方法
Sep 02 Javascript
ES6箭头函数和扩展实例分析
May 23 Javascript
JavaScript轮播停留效果的实现思路
May 24 #Javascript
vue2单元测试环境搭建
May 24 #Javascript
Vue+mui实现图片的本地缓存示例代码
May 24 #Javascript
vue组件name的作用小结
May 23 #Javascript
linux 后台运行node服务指令方法
May 23 #Javascript
node.js部署之启动后台运行forever的方法
May 23 #Javascript
jquery引入外部CDN 加载失败则引入本地jq库
May 23 #jQuery
You might like
测试您的 PHP 水平的题目
2007/05/30 PHP
PHP curl 并发最佳实践代码分享
2012/09/05 PHP
php微信公众号开发之答题连闯三关
2018/10/20 PHP
简述jQuery ajax的执行顺序
2016/01/05 Javascript
js获取鼠标点击的对象,点击另一个按钮删除该对象的实现代码
2016/05/13 Javascript
KnockoutJS 3.X API 第四章之表单value绑定
2016/10/10 Javascript
前端js实现文件的断点续传 后端PHP文件接收
2016/10/14 Javascript
connection reset by peer问题总结及解决方案
2016/10/21 Javascript
AngularJS使用带属性值的ng-app指令实现自定义模块自动加载的方法
2017/01/04 Javascript
关于bootstrap日期转化,bootstrap-editable的简单使用,bootstrap-fileinput的使用详解
2017/05/12 Javascript
微信小程序 实现点击添加移除class
2017/06/12 Javascript
分享vue.js devtools遇到一系列问题
2017/10/24 Javascript
详解如何使用node.js的开发框架express创建一个web应用
2018/12/20 Javascript
更优雅的微信小程序骨架屏实现详解
2019/08/07 Javascript
Python备份Mysql脚本
2008/08/11 Python
Python random模块常用方法
2014/11/03 Python
Python解决鸡兔同笼问题的方法
2014/12/20 Python
Python的迭代器和生成器
2015/07/29 Python
简析Python的闭包和装饰器
2016/02/26 Python
Python+tkinter模拟“记住我”自动登录实例代码
2018/01/16 Python
Python 函数基础知识汇总
2018/03/09 Python
pandas DataFrame 根据多列的值做判断,生成新的列值实例
2018/05/18 Python
python 获得任意路径下的文件及其根目录的方法
2019/02/16 Python
利用ImageAI库只需几行python代码实现目标检测
2019/08/09 Python
python词云库wordCloud使用方法详解(解决中文乱码)
2020/02/17 Python
Python中import导入不同目录的模块方法详解
2020/02/18 Python
python新手学习使用库
2020/06/11 Python
Theo + George官方网站:都柏林时尚品牌
2019/04/08 全球购物
评析教师个人的自我评价
2014/02/19 职场文书
学生安全责任书
2014/04/15 职场文书
给妈妈洗脚活动方案
2014/08/16 职场文书
校园运动会广播稿
2014/10/06 职场文书
2015年社区工会工作总结
2015/05/26 职场文书
大学组织委员竞选稿
2015/11/21 职场文书
win10+RTX3050ti+TensorFlow+cudn+cudnn配置深度学习环境的方法
2022/06/25 Servers
CSS 实现磨砂玻璃(毛玻璃)效果样式
2023/05/21 HTML / CSS