iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > 其他 >es6暂时性死区是什么意思
  • 568
分享到

es6暂时性死区是什么意思

暂时性死区ES6 2023-05-14 22:05:00 568人浏览 独家记忆
摘要

本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。什么是暂时性死区 es6中,在代码块内,使用let/const命令声明变量之前,该变量都是不可用的,在变量声明之前属于该变量的“死区”。这在语法上,称为“

es6暂时性死区是什么意思

教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。

什么是暂时性死区

es6中,在代码块内,使用let/const命令声明变量之前,该变量都是不可用的,在变量声明之前属于该变量的“死区”。这在语法上,称为“暂时性死区”(temporal dead zone,简称 TDZ)。ES标准并没有明确提出TDZ,但我们常用其描述let、const的不提升效果。

let/const和var的区别

在ES6之前,js的scope只有两种,全局作用域和函数作用域,但是在ES6种出现了块级作用域,即使用let/const可以定义块级作用域。 那么在ES6的新特性中,最容易看到TDZ作用的就是使用let/const的使用上面。 let/const与var的主要不同有两个地方:

  • let/const是使用区块作用域;var是使用函数作用域
  • 在let/const声明之前就访问对应的变量与常量,会抛出ReferenceError错误;但在var声明之前就访问对应的变量,则会得到undefined
console.log(Vname); // undefined;
console.log(Lname); // ReferenceError
var Vname = 'xiaoxiao';
let Lname = 'xiaoxiao';

实践证明当我们在未声明之前使用var定义的变量时会得到undefined,但是在使用let未定义的变量时会抛出错误。因为ES6中的let声明的变量是不存在变量提升的作用。

var x = 10;
if (true) {
    x = 20; // ReferenceError
    let x;
 }

ES6 明确规定,如果区块中存在let和const命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错。 总之,在代码块内,使用let命令声明变量之前,该变量都是不可用的。这在语法上,称为“暂时性死区”(temporal dead zone,简称 TDZ)。

if (true) {
  // TDZ开始
  tmp = 'abc'; // ReferenceError
  console.log(tmp); // ReferenceError

  let tmp; // TDZ结束
  console.log(tmp); // undefined

  tmp = 123;
  console.log(tmp); // 123
}

上面代码中,在let命令声明变量tmp之前,都属于变量tmp的“死区”。

typeof的“死区”陷阱

我们都知道使用typeof 可以用来检测给定变量的数据类型,也可以使用它来判断值是否被定义。当返回undefined时表示值未定义; 但是在const/let定义的变量在变量声明之前如果使用了typeof就会报错

typeof x; // ReferenceError
let x;

因为x是使用let声明的,那么在x未声明之前都属于暂时性死区,在使用typeof时就会报错。所以在使用let/const进行声明的变量在使用typeof时不一定安全喔。

typeof y; // 'undefined'

但是可以看出,如果我们只是用了typeof而没有去定义,也是不会报错的,从这粒可以看出只要没有明确规定使用const/let定义之前就是不会出错。

传参的“死区”陷阱

例如下面一段代码,我们在使用

function bar(x = y, y = 2) {
  return [x, y];
}

bar(); // 报错

上面代码中,调用bar函数之所以报错(某些实现可能不报错),是因为参数x默认值等于另一个参数y,而此时y还没有声明,属于”死区“。如果y的默认值是x,就不会报错,因为此时x已经声明了。

function bar(x = 2, y = x) {
  return [x, y];
}
bar(); // [2, 2]

使用var和let声明的另外一种区别。

// 不报错
var x = x;

// 报错
let x = x;
// ReferenceError: x is not defined

受“死区”的影响,使用let声明变量时,只要变量在还没有声明完成前使用,就会报错。上面这行就属于这个情况,在变量x的声明语句还没有执行完成前,就去取x的值,导致报错”x 未定义“。

总结

ES6 规定暂时性死区和let、const语句不出现变量提升,主要是为了减少运行时错误,防止在变量声明前就使用这个变量,从而导致意料之外的行为。这样的错误在 ES5 是很常见的,现在有了这种规定,避免此类错误就很容易了。

总之,暂时性死区的本质就是,只要一进入当前作用域,所要使用的变量就已经存在了,但是不可获取,只有等到声明变量的那一行代码出现,才可以获取和使用该变量。

注: TDZ最一开始是为了const所设计的,但后来的对let的设计也是一致的。

注: 在ES6标准中,对于const所声明的识别子仍然也经常为variable(变量),称为constant variable(固定的变量)。以const声明所创建出来的常量,在JS中只是不能再被赋(can't re-assignment),并不是不可被改变(immutable)的,这两种概念仍然有很大的差异。

【相关推荐:javascript视频教程、web前端

以上就是es6暂时性死区是什么意思的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: es6暂时性死区是什么意思

本文链接: https://www.lsjlt.com/news/206501.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • es6暂时性死区是什么意思
    本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。什么是暂时性死区 ES6中,在代码块内,使用let/const命令声明变量之前,该变量都是不可用的,在变量声明之前属于该变量的“死区”。这在语法上,称为“...
    99+
    2023-05-14
    暂时性死区 ES6
  • es6暂时性死区指的是什么
    这篇“es6暂时性死区指的是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“es6暂时性死区指的是什么”文章吧。在es6中...
    99+
    2023-07-04
  • es6中暂时性死区的含义是什么
    本文小编为大家详细介绍“es6中暂时性死区的含义是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“es6中暂时性死区的含义是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。...
    99+
    2024-04-02
  • 浅谈JavaScript暂时性死区与垃圾回收机制
    目录暂时性死区(TDZ)暂时性死区是什么js垃圾回收机制内存泄漏垃圾回收机制暂时性死区(TDZ) 暂时性死区是什么 我们来看一个例子 var tmp = 123; if (tru...
    99+
    2023-05-18
    JavaScript暂时性死区 JavaScript垃圾回收机制
  • es6中yield指的是什么意思
    小编给大家分享一下es6中yield指的是什么意思,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 在...
    99+
    2024-04-02
  • es6中map指的是什么意思
    这篇文章将为大家详细讲解有关es6中map指的是什么意思,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 在es6中,map是一种数据结构,是“...
    99+
    2024-04-02
  • 一文读懂JS中的var/let/const和暂时性死区
    目录js中变量的特征变量的定义与访问简单说下作用域语法varlet与暂时性死区constjs中变量的特征 js的变量是松散类型的。变量可以用于保存任何类型的数据。所以js也被称为弱类...
    99+
    2023-02-27
    JS var let const JS var JS let JS const
  • JS中的var/let/const和暂时性死区实例分析
    本篇内容介绍了“JS中的var/let/const和暂时性死区实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!js中变量的特征js的变...
    99+
    2023-07-05
  • es6生成器指的是什么意思
    这篇文章将为大家详细讲解有关es6生成器指的是什么意思,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 在es6中,生成器是设置迭代器的一个函数...
    99+
    2024-04-02
  • 区间价是什么意思
    区间价是指一个数值或价格在一定范围内的波动或变化,帮助人们理解或衡量价格的波动性,并提供了一种识别和比较价格范围的方法。本教程操作系统:Windows10系统、Dell G3电脑。在商业和金融领域,"区间价"是指某个价值...
    99+
    2023-08-16
  • es6中三个点指的是什么意思
    这篇文章给大家分享的是有关es6中三个点指的是什么意思的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 在es6中,三个点“...”指的是“扩展运算符”...
    99+
    2024-04-02
  • HTML属性是什么意思
    这篇文章主要介绍了HTML属性是什么意思,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 HTML - 属性 前言 HTML属性是HTM...
    99+
    2024-04-02
  • 弹性ip是什么意思
    弹性ip指的是一台服务器在启动实例时,会自动将每个实例分配给一个私有IP地址和一个公共IP地址的意思。可以将此IP绑定到任意云主机上,实现随时升级而不关闭服务器功能。弹性IP地址是在 EC2 启动实例时,自动地为每个实例分配一个私有 IP ...
    99+
    2024-04-02
  • es6 等号箭头什么意思
    本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。=>是箭头函数,是ES6标准中新增的一种新的函数。顾名思义,箭头函数是一种使用箭头(=>)定义函数的新语法,箭头函数表达式的语法比函数表达式更...
    99+
    2022-11-22
    ES6 javascript
  • javascript时间戳是什么意思
    这篇文章主要介绍javascript时间戳是什么意思,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 在javascript中,时间戳(timestamp)...
    99+
    2024-04-02
  • CSS border属性是什么意思
    CSS border属性用于设置元素的边框样式、宽度和颜色。它可以在一行代码中设置所有的边框属性,也可以分别设置每个边框的样式、宽度...
    99+
    2023-10-11
    CSS
  • 云服务器暂不支持什么意思
    云服务器不支持的原因可能有很多种,具体原因可能包括以下几个方面: 配置错误:当云服务器配置存在错误时,可能无法运行您的应用程序。这种情况下,您可能需要检查云服务器的配置并修复您的配置错误。 服务不可用:当云服务器出现故障或服务不可用时,...
    99+
    2023-10-27
    什么意思 暂不 服务器
  • MySQL中分区表是什么意思
    这篇文章主要介绍MySQL中分区表是什么意思 ,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!对于用户而言,分区表是一个独立的逻辑表,但是在底层由多个物理子表组成。实现分区的代码实际上...
    99+
    2024-04-02
  • J2EE是什么意思2又是什么意思
    J2EE是Java 2 Platform, Enterprise Edition的缩写,意思是Java 2企业级平台。它是一种用于开...
    99+
    2023-09-20
    J2EE
  • 弹性公网ip是什么意思
    弹性公网ip是一种NAT IP,它能够提供独立的公网ip资源,其中包括公网ip地址与公网出口带宽服务,如果一台云主机绑定了弹性公网ip,就可以直接使用该弹性公网ip进行公网通信,需要注意的是一个弹性公网ip只能绑定一台云主机使用。弹性公网I...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作