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 相关文章推荐
jqPlot jquery的页面图表绘制工具
Jul 25 Javascript
jquery弹出关闭遮罩层实例
Aug 06 Javascript
浏览器图片选择预览、旋转、批量上传的JS代码实现
Dec 04 Javascript
如何实现textarea里的不同文本显示不同颜色
Jan 20 Javascript
JavaScript统计网站访问次数的实现代码
Nov 18 Javascript
JS基于MSClass和setInterval实现ajax定时采集信息并滚动显示的方法
Apr 18 Javascript
Bootstrap Metronic完全响应式管理模板之菜单栏学习笔记
Jul 08 Javascript
JS动态加载脚本并执行回调操作
Aug 24 Javascript
jQuery窗口拖动功能的实现代码
Feb 04 Javascript
JQuery用$.ajax或$.getJSON跨域获取JSON数据的实现代码
Sep 23 jQuery
解决vue打包css文件中背景图片的路径问题
Sep 03 Javascript
JavaScript指定断点操作实例教程
Sep 18 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
使用网络地址转换实现多服务器负载均衡
2006/10/09 PHP
五个PHP程序员工具
2008/05/26 PHP
色色整理的PHP面试题集锦
2012/03/08 PHP
PHP读取文件内容后清空文件示例代码
2014/03/18 PHP
php+html5实现无刷新图片上传教程
2016/01/22 PHP
全面解析PHP验证码的实现原理 附php验证码小案例
2016/08/17 PHP
一个实用的php验证码类
2017/07/06 PHP
Laravel框架Auth用户认证操作实例分析
2019/09/29 PHP
php实现记事本案例
2020/10/20 PHP
新浪的图片新闻效果
2007/01/13 Javascript
javascript js cookie的存储,获取和删除
2007/12/29 Javascript
JavaScript 版本自动生成文章摘要
2008/07/23 Javascript
Javascript学习笔记之函数篇(五) : 构造函数
2014/11/23 Javascript
javascript中字体浮动效果的简单实例演示
2015/11/18 Javascript
基于Bootstrap的UI扩展 StyleBootstrap
2016/06/17 Javascript
jQuery电话号码验证实例
2017/01/05 Javascript
总结几道关于Node.js的面试问题
2017/01/11 Javascript
JS实现点击表头表格自动排序(含数字、字符串、日期)
2017/01/22 Javascript
Vue Router的懒加载路径的解决方法
2018/06/21 Javascript
bootstrap tooltips在 angularJS中的使用方法
2019/04/10 Javascript
vue中$refs, $emit, $on, $once, $off的使用详解
2019/05/26 Javascript
小程序实现点击tab切换左右滑动
2020/11/16 Javascript
详解Vue的mixin策略
2020/11/19 Vue.js
详谈Python2.6和Python3.0中对除法操作的异同
2017/04/28 Python
python实现停车管理系统
2018/11/30 Python
Python 获取div标签中的文字实例
2018/12/20 Python
python使用Plotly绘图工具绘制柱状图
2019/04/01 Python
CSS实现聊天气泡效果
2020/04/26 HTML / CSS
利用HTML5+css3+jquery+weui实现仿微信聊天界面功能
2018/01/08 HTML / CSS
美国在线宠物用品商店:Entirely Pets
2017/01/01 全球购物
家得宝官网:The Home Depot(全球最大的家居装饰专业零售商)
2018/12/17 全球购物
西班牙最好的在线购买葡萄酒的商店:Vinoseleccion
2019/10/30 全球购物
大学生个人求职信
2014/06/02 职场文书
反腐倡廉标语
2014/06/24 职场文书
暖春观后感
2015/06/08 职场文书
教师远程研修感悟
2015/11/18 职场文书