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 相关文章推荐
javascript 兼容所有浏览器的DOM扩展功能
Aug 01 Javascript
javascript小数四舍五入多种方法实现
Dec 23 Javascript
js弹出框轻量级插件jquery.boxy使用介绍
Jan 15 Javascript
jquery 页面滚动到指定DIV实现代码
Sep 25 Javascript
基于jquery实现瀑布流布局
Jun 28 Javascript
fullCalendar中文API官方文档
Feb 07 Javascript
javascript计算对象长度的方法
Oct 25 Javascript
webpack4+Vue搭建自己的Vue-cli项目过程分享
Aug 29 Javascript
node.js的http.createServer过程深入解析
Jun 06 Javascript
Vue.js 无限滚动列表性能优化方案
Dec 02 Javascript
vue项目查看vue版本及cli版本的实现方式
Oct 24 Javascript
微前端qiankun改造日渐庞大的项目教程
Jun 21 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 多文件上传的实现实例
2016/10/23 PHP
PHP使用Redis替代文件存储Session的方法
2017/02/15 PHP
指定js可访问其它域名的cookie的方法
2007/09/18 Javascript
jquery 最简单的属性菜单
2009/10/08 Javascript
js获得当前时区夏令时发生和终止的时间代码
2014/02/23 Javascript
用于deeplink的js方法(判断手机是否安装app)
2014/04/02 Javascript
jQuery实现左侧导航模块的显示与隐藏效果
2016/07/04 Javascript
用jQuery实现圆点图片轮播效果
2017/03/19 Javascript
Material(包括Material Icon)在Angular2中的使用详解
2018/02/11 Javascript
vue中子组件向父组件传递数据的实例代码(实现加减功能)
2018/04/20 Javascript
微信小程序项目实践之验证码倒计时功能
2018/07/18 Javascript
微信小程序实现指定显示行数多余文字去掉用省略号代替
2018/07/25 Javascript
vue项目中,main.js,App.vue,index.html的调用方法
2018/09/20 Javascript
js实现图片无缝循环轮播
2019/10/28 Javascript
使用webpack/gulp构建TypeScript项目的方法示例
2019/12/18 Javascript
[01:17]Ti4 循环赛第一日回顾
2014/07/11 DOTA
探索Python3.4中新引入的asyncio模块
2015/04/08 Python
Python编程中的文件读写及相关的文件对象方法讲解
2016/01/19 Python
Python while 循环使用的简单实例
2016/06/08 Python
python爬虫系列Selenium定向爬取虎扑篮球图片详解
2017/11/15 Python
K-近邻算法的python实现代码分享
2017/12/09 Python
python3解析库BeautifulSoup4的安装配置与基本用法
2018/06/26 Python
Python 使用PIL中的resize进行缩放的实例讲解
2018/08/03 Python
python中with用法讲解
2020/02/07 Python
浅谈Python中range与Numpy中arange的比较
2020/03/11 Python
使用Keras画神经网络准确性图教程
2020/06/15 Python
美国摄影爱好者购物网站:Focus Camera
2016/10/21 全球购物
巴西女装购物网站:Eclectic
2018/04/24 全球购物
Made in Design意大利:现代家具、名家灯具和装饰
2020/10/27 全球购物
Java语言的优势
2015/01/10 面试题
森林防火标语
2014/06/23 职场文书
故意伤害人身损害赔偿协议书
2014/11/19 职场文书
2014年女职工工作总结
2014/11/27 职场文书
2016年党员创先争优承诺书
2016/03/25 职场文书
浅谈node.js中间件有哪些类型
2021/04/29 Javascript
Java数据开发辅助工具Docker与普通程序使用方法
2021/09/15 Java/Android