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 相关文章推荐
jquery animate实现鼠标放上去显示离开隐藏效果
Jul 21 Javascript
jQuery 中国省市两级联动选择附图
May 14 Javascript
使用JS+plupload直接批量上传图片到又拍云
Dec 01 Javascript
JavaScript将当前时间转换成UTC标准时间的方法
Apr 06 Javascript
Jquery-1.9.1源码分析系列(十一)之DOM操作
Nov 25 Javascript
Jquery插件easyUi实现表单验证示例
Dec 15 Javascript
javascript HTML5 Canvas实现圆盘抽奖功能
Apr 11 Javascript
Bootstrap弹出框modal上层的输入框不能获得焦点问题的解决方法
Dec 13 Javascript
详解 微信小程序开发框架(MINA)
May 17 Javascript
转换layUI的数据表格中的日期格式方法
Sep 19 Javascript
p5.js临摹动态图形实现方法详解
Oct 23 Javascript
vue引入静态js文件的方法
Jun 20 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-cgi.exe - FastCGI 进程超过了配置的请求超时时限)的问题
2013/07/03 PHP
PHP生成唯一订单号
2015/07/05 PHP
解决更换PHP5.4以上版本后Dedecms后台登录空白问题的方法
2015/10/23 PHP
PHP Oauth授权和本地加密实现方法
2016/08/12 PHP
php中Redis的应用--消息传递
2017/03/28 PHP
phpinfo无法显示的原因及解决办法
2019/02/15 PHP
js数字输入框(包括最大值最小值限制和四舍五入)
2009/11/24 Javascript
javascript框架设计读书笔记之数组的扩展与修复
2014/12/02 Javascript
jquery图片播放浏览插件prettyPhoto使用详解
2014/12/19 Javascript
浅谈JavaScript异常处理语句
2015/06/26 Javascript
jQuery实现可用于博客的动态滑动菜单完整实例
2015/09/17 Javascript
在Ubuntu系统上安装Node.JS的教程
2015/10/15 Javascript
jQuery EasyUI编辑DataGrid用combobox实现多级联动
2016/08/29 Javascript
Bootstrap的基本应用要点浅析
2016/12/19 Javascript
Vue.js如何优雅的进行form validation
2017/04/07 Javascript
angular4中关于表单的校验示例
2017/10/16 Javascript
js 将canvas生成图片保存,或直接保存一张图片的实现方法
2018/01/02 Javascript
vue cli2.0单页面title修改方法
2018/06/07 Javascript
element-ui 中的table的列隐藏问题解决
2018/08/24 Javascript
electron制作仿制qq聊天界面的示例代码
2018/11/26 Javascript
[03:02]2020完美世界城市挑战赛(秋季赛)总决赛回顾
2021/03/11 DOTA
在Python的Django框架中生成CSV文件的方法
2015/07/22 Python
python爬虫框架talonspider简单介绍
2017/06/09 Python
Python队列的定义与使用方法示例
2017/06/24 Python
Python3.6简单反射操作示例
2018/06/14 Python
django 类视图的使用方法详解
2019/07/24 Python
python实现文件批量编码转换及注意事项
2019/10/14 Python
解决Alexnet训练模型在每个epoch中准确率和loss都会一升一降问题
2020/06/17 Python
咖啡为什么会有酸味?你喝到的咖啡為什麼是酸的?
2021/03/17 冲泡冲煮
html5中的一些标签学习(心得)
2016/10/18 HTML / CSS
HTML5+CSS设置浮动却没有动反而在中间且错行的问题
2020/05/26 HTML / CSS
Miller Harris官网:英国小众香水品牌
2020/09/24 全球购物
Yahoo-PHP面试题3
2012/01/14 面试题
叙述DBMS对数据控制功能有哪些
2016/06/12 面试题
个人近期表现材料
2014/02/11 职场文书
大学生村官座谈会发言材料
2014/05/25 职场文书