热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

深切明白let和var的区分(暂时性死区)!!!

起首我们应当晓得js引擎在读取js代码时会举行两个步骤:第一个步骤是诠释。第二个步骤是实行。所谓诠释就是会先通篇扫描一切的Js代码,然后把一切声明提拔到顶端,第二步是实行,实行就是

起首我们应当晓得js引擎在读取js代码时会举行两个步骤:

  • 第一个步骤是诠释。
  • 第二个步骤是实行。

所谓诠释就是会先通篇扫描一切的Js代码,然后把一切声明提拔到顶端,第二步是实行,实行就是操纵一类的。

我们先来看个简朴的变量提拔案例吧

a = 'Javascript';
var a;
console.log(a);//'Javascript'

console.log(b);//undefined
var b='Javascript'

碰到 script 标签的话 js 就举行预剖析,将变量 var 和 function 声明提拔,但不会实行 function,然后就进入上下文实行,上下文实行照样实行预剖析一样操纵,直到没有 var 和 function,就最先实行上下文。如:

a=5;
show();
var a;
function show(){};

预剖析:

function show(){};
var a;
a=5;
show();

须要注重都是函数声明提拔直接把全部函数提到实行环境的最顶端。

那末let/const和var又有什么区别呢??

  • let/const是运用区块作用域;var是运用函数作用域。
  • 在let/const声明之前就接见对应的变量与常量,会抛出ReferenceError毛病;但在var声明之前就接见对应的变量,则会获得undefined。

console.log(aVar) // undefined
console.log(aLet) // causes ReferenceError: aLet is not defined
var aVar = 1
let aLet = 2

会涌现如许的状况是由于let/const具有“临时性死区(TDZ)”。

什么是临时性死区?

当顺序的掌握流程在新的作用域(module, function或block作用域)举行实例化时,在此作用域中的用let/const声明的变量会先在作用域中被建立出来,但因此时还未举行词法绑定,也就是对声明语句举行求值运算,所以是不能被接见的,接见就会抛出毛病。所以在这运转流程一进入作用域建立变量,到变量最先可被接见之间的一段时间,就称之为TDZ(临时死区)。

结论:let/const声明的变量,确实也是有提拔(hoist)的作用。这个是很轻易被误会的处所,实际上以let/const声明的变量也是会有提拔(hoist)的作用。提拔是JS语言中关于变量声明的基础特征,只是由于TDZ的作用,并不会像运用var来声明变量,只是会获得undefined罢了,如今则是会直接抛出ReferenceError毛病,而且很明显的这是一个在运转时期才会涌现的毛病。

ES6 划定临时性死区和let、const语句不涌现变量提拔,重要是为了削减运转时毛病,防备在变量声明前就运用这个变量,从而致使意料之外的行动。如许的毛病在 ES5 是很罕见的,如今有了这类划定,防止此类毛病就很轻易啦~


推荐阅读
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • 本文介绍了如何利用JavaScript或jQuery来判断网页中的文本框是否处于焦点状态,以及如何检测鼠标是否悬停在指定的HTML元素上。 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • 导航栏样式练习:项目实例解析
    本文详细介绍了如何创建一个具有动态效果的导航栏,包括HTML、CSS和JavaScript代码的实现,并附有详细的说明和效果图。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • Java 中 Writer flush()方法,示例 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 探讨一个显示数字的故障计算器,它支持两种操作:将当前数字乘以2或减去1。本文将详细介绍如何用最少的操作次数将初始值X转换为目标值Y。 ... [详细]
author-avatar
万梅同芳正当时
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有