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 相关文章推荐
小型js框架veryide.librar源代码
Mar 05 Javascript
各浏览器对link标签onload/onreadystatechange事件支持的差异分析
Apr 27 Javascript
在jquery中处理带有命名空间的XML数据
Jun 13 Javascript
JS中typeof与instanceof之间的区别总结
Nov 14 Javascript
标题过长使用javascript按字节截取字符串
Apr 24 Javascript
通过点击jqgrid表格弹出需要的表格数据
Dec 02 Javascript
JS获取鼠标选中的文字
Aug 10 Javascript
微信小程序中form 表单提交和取值实例详解
Apr 20 Javascript
JavaScript实现的贝塞尔曲线算法简单示例
Jan 30 Javascript
微信小程序实现用table显示数据库反馈的多条数据功能示例
May 07 Javascript
layui监听select变化,以及设置radio选中的方法
Sep 24 Javascript
el-table树形表格表单验证(列表生成序号)
May 31 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模板类代码
2008/09/07 PHP
php对二维数组进行相关操作(排序、转换、去空白等)
2015/11/04 PHP
PHP模块化安装教程
2016/06/01 PHP
PHP的时间戳与具体时间转化的简单实现
2016/06/13 PHP
PHP一个简单的无需刷新爬虫
2019/01/05 PHP
js 动态文字滚动的例子
2011/01/17 Javascript
关于使用 jBox 对话框的提交不能弹出问题解决方法
2012/11/07 Javascript
javascript ajax 仿百度分页函数
2013/10/29 Javascript
Node.js中安全调用系统命令的方法(避免注入安全漏洞)
2014/12/05 Javascript
jQuery拖动布局其结果保存到数据库
2015/10/09 Javascript
KnockoutJS 3.X API 第四章之事件event绑定
2016/10/10 Javascript
JS中的phototype详解
2017/02/04 Javascript
JavaScript 实现 Tab 点击切换实例代码
2017/03/25 Javascript
Angular2.0/4.0 使用Echarts图表的示例代码
2017/12/07 Javascript
原生js实现商品筛选功能
2019/10/28 Javascript
vue 中 elment-ui table合并上下两行相同数据单元格
2019/12/26 Javascript
基于JS正则表达式实现模板数据动态渲染(实现思路详解)
2020/03/07 Javascript
VSCode launch.json配置详细教程
2020/06/18 Javascript
[01:13]这,就是刀塔
2014/07/16 DOTA
[50:48]LGD vs CHAOS 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/16 DOTA
python使用wxpython开发简单记事本的方法
2015/05/20 Python
python实现JAVA源代码从ANSI到UTF-8的批量转换方法
2015/08/10 Python
python中正则的使用指南
2016/12/04 Python
处理python中多线程与多进程中的数据共享问题
2019/07/28 Python
Python 用三行代码提取PDF表格数据
2019/10/13 Python
Python文字截图识别OCR工具实例解析
2020/03/05 Python
Python request操作步骤及代码实例
2020/04/13 Python
python 比较字典value的最大值的几种方法
2020/04/17 Python
Selenium及python实现滚动操作多种方法
2020/07/21 Python
浅析NumPy 切片和索引
2020/09/02 Python
DC Shoes官网:美国滑板鞋和服饰品牌
2017/09/03 全球购物
abstract class和interface有什么区别?
2012/01/03 面试题
打架检讨书100字
2014/01/08 职场文书
个人综合鉴定材料
2014/05/23 职场文书
普通话演讲稿
2014/09/03 职场文书
详解PyTorch模型保存与加载
2022/04/28 Python