详解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 相关文章推荐
Node.js:Windows7下搭建的Node.js服务(来玩玩服务器端的javascript吧,这可不是前端js插件)
Jun 27 Javascript
解决ExtJS在chrome或火狐中正常显示在ie中不显示的浏览器兼容问题
Jan 11 Javascript
jquery dialog open后,服务器端控件失效的快速解决方法
Dec 19 Javascript
JavaScript自定义日期格式化函数详细解析
Jan 14 Javascript
js获取当前地址 JS获取当前URL的示例代码
Feb 26 Javascript
javascript实现按回车键切换焦点
Feb 09 Javascript
如何用JavaScript实现动态修改CSS样式表
May 20 Javascript
jQuery动态加载css文件实现方法
Jun 15 Javascript
Vue.js常用指令汇总(v-if、v-for等)
Nov 03 Javascript
javascript html5轻松实现拖动功能
Mar 01 Javascript
微信小程序实现swiper切换卡内嵌滚动条不显示的方法示例
Dec 20 Javascript
echarts多条折线图动态分层的实现方法
May 24 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中取得URL的根域名的代码
2011/03/23 PHP
PHP输入流php://input介绍
2012/09/18 PHP
分享一个超好用的php header下载函数
2014/01/31 PHP
laravel 实现关闭CSRF(全部关闭、部分关闭)
2019/10/21 PHP
浅谈PHP之ThinkPHP框架使用详解
2020/07/21 PHP
关于query Javascript CSS Selector engine
2013/04/12 Javascript
JQuery制作的放大效果的popup对话框(未添加任何jquery plugin)分享
2013/04/28 Javascript
JavaScript cookie的设置获取删除详解
2014/02/11 Javascript
jQuery实现鼠标单击网页文字后在文本框显示的方法
2015/05/06 Javascript
js实现将选中值累加到文本框的方法
2015/08/12 Javascript
jquery实现带渐变淡入淡出并向右依次展开的多级菜单效果实例
2015/08/22 Javascript
js判断是否为空和typeof的用法(详解)
2016/10/07 Javascript
jQuery动态添加与删除tr行实例代码
2016/10/18 Javascript
jQuery实现倒计时重新发送短信验证码功能示例
2017/01/12 Javascript
vue2.0+koa2+mongodb实现注册登录
2018/04/10 Javascript
js中比较两个对象是否相同的方法示例
2019/09/02 Javascript
JS替换字符串中指定位置的字符(多种方法)
2020/05/28 Javascript
浅析JavaScript 函数柯里化
2020/09/08 Javascript
[01:03:51]2018DOTA2亚洲邀请赛 4.7 淘汰赛 VP vs LGD 第三场
2018/04/09 DOTA
Windows8下安装Python的BeautifulSoup
2015/01/22 Python
Python3之文件读写操作的实例讲解
2018/01/23 Python
python多线程实现TCP服务端
2019/09/03 Python
使用python实现kNN分类算法
2019/10/16 Python
Python 数据的累加与统计的示例代码
2020/08/03 Python
python爬虫中抓取指数的实例讲解
2020/12/01 Python
深入浅析css3 中display box使用方法
2015/11/25 HTML / CSS
浅析HTML5 Landmark
2020/09/11 HTML / CSS
荷兰本土平价百货:HEMA
2017/10/23 全球购物
国际书籍零售商:Wordery
2017/11/01 全球购物
德国亚马逊官方网站:Amazon.de
2020/11/15 全球购物
《故都的秋》教学反思
2014/04/15 职场文书
学习十八大的心得体会
2014/09/12 职场文书
2014乡镇机关党员个人对照检查材料思想汇报
2014/10/09 职场文书
孔繁森观后感
2015/06/10 职场文书
青涩记忆观后感
2015/06/18 职场文书
公司要求试用期员工提交“述职报告”,该怎么写?
2019/07/17 职场文书