位置: 编程技术 - 正文

浅谈ECMAScript6新特性之let、const(ecmascript6 官方文档)

编辑:rootadmin

推荐整理分享浅谈ECMAScript6新特性之let、const(ecmascript6 官方文档),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:ecmascript7,ecmascript6教程,ecmascript6 官方文档,ecmascript 6,ecmascript5.1,ecmascript6入门,ecmascript6入门,ecmascript6入门,内容如对您有帮助,希望把文章链接给更多的朋友!

第一次写博客有点紧张,如果说的不对的地方,欢迎大家留言指正。咱们先来说说“ECMAScript”这到底是啥玩意儿?它和javascript的关系又是如何的?首先,在年月的时候,javascript的创造者(网景公司Netscape)和sun公司联合ECMA(欧洲计算机制造商协会)对javascript进行标准化,次年,ECMA发布号标准文件文件(ECMA-)的第一版,规定了浏览器脚本语言的标准(在这里提个问题:为什么要标准化?),并将这种语言称为ECMAScript,这个版本就是1.0版的。这个标准一开始就是针对与javascript来制定的,但是没有称之为“javascript”,这其中有两个原因,一是:商标;二是:想体现这门语言的规格制定者是ECMA,这样有利于保证开发性和中立性。所以,ECMAScript和javascript之间的关系就是,前者来制定规格,后者来实现(另外的ECMAScript的实现还有JScript和ActionScript)。一般的情况下,这两个词是可以互换的。

接下来来介绍一下es6中的新特性之“let”。首先,这个玩意儿其实和var这个命令类似,都是用于声明变量的,但是所声明的变量只在let命令所在的代码块内有效(这里涉及到块级作用域的概念,然而这个概念也是es6中提出来的。在后面我再来讲。PS:在其他编程语言中,早就有块级了)

上面的两张图就反映出了let所声明的变量只在let命令所在的代码块内有效。下面来举个例子:

发现区别了吗?var声明的变量它是全局范围内都有效的,每一次的循环,新的i值都会覆盖旧值,导致最后输出的是最后一轮的i值(当然,也可以利用闭包来解决这个问题【第三张图】)。如果使用的是let,声明的变量仅在块级作用域内有效,当前的i只在本轮循环有效,所以每一次循环i其实都是一个新的变量。在期间我发现了一个更神奇的东西,请看下面一张图:

注意:①、let不像var一样会发生“变量提升”的现象,所以,使用之前,必须先声明,不然就会报错。

②、暂时性死区(temporal dead zone,简称TDZ),只要块级作用域内有let命令,它所声明的变量就会绑定这个区域,不收外部的的影响。简单的来说,在代码块中,使用let命令声明变量之前,变量都是不能用的。例子:

③、let不允许在同一个作用域内重复声明同一个变量。

浅谈ECMAScript6新特性之let、const(ecmascript6 官方文档)

好了,现在再来讲一讲上文提及到的一个东东:“块级作用域”。在es5中只有“全局作用域”和“函数作用域”。这使得我在刚开始学的时候一脸蒙蔽,其他语言都有块级作用域(比如C语言),但js就没有。幸好在es6中加入了“块级作用域”的概念,let实际上为javascript新增了块级作用域,有了块级作用域,就可以避免变量泄露成全局变量,代码快之间不会受到影响。另外,es6里还规定了:函数本身的作用域在其块级作用域内。注意!注意!注意!重要的事说三遍:(如果是在严格模式下,函数只能在顶级作用域和函数内部声明,其他情况下【比如:if语句、循环语句下】就会报错) :

最后再来说说es6中的新特性之“const”,好吧,其他编程语言里早就有了,但是javascript在es6之前还是没有~~。这个是用来声明常量的,其表现为不可修改的,还有就是声明的同时必须进行赋值,否则就会报错。

注意:①、在作用域方面,它其实和let作用域相同:只在声明所在的块级作用域内有效;

 ②、const命令声明的常量同样不存在“变量提升”,同样存在“暂时性死区”,必须在声明后才能使用。

 ③、const也不能重复声明常量。

综合例子:

 ④、对于复合类型的变量,常量名不指向数据,而是指向的是数据的指针地址,const命令只是保证了地址没有变,但并不保证数据的不变,所以在使用const命令声明常量为对象时要小心!!其实我们可以对其对象进行“冻结”,使用Object.freeze()即可实现。

以上这篇浅谈ECMAScript6新特性之let、const就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持积木网。

老生常谈js数据类型 js数据类型主要分为基本数据类型和引用数据类型基本数据类型和引用数据类型的区别:基本数据类型是对值得引用,引用数据类型是对地址的引用;基

JS对象与JSON互转换、New Function()、 forEach()、DOM事件流等js开发基础小结 1、数据类型:JavaScript定义的数据类型有字符串、数字、布尔、数组、对象、Null、Undefined,但typeof有区分可判别的数据分类是number、string、boolean、object(

Mobile Web开发基础之四--处理手机设备的横竖屏问题 为了应对移动设备屏幕的碎片化,我们在开发MobileWeb应用时,一个最佳实践就是采用流式布局,保证最大可能地利用有限的屏幕空间。由于屏幕存在着

标签: ecmascript6 官方文档

本文链接地址:https://www.jiuchutong.com/biancheng/377531.html 转载请保留说明!

上一篇:基于JS脚本语言的基础语法详解(js的脚本语言)

下一篇:JS对象与JSON互转换、New Function()、 forEach()、DOM事件流等js开发基础小结(简述js json对象和字符串的转换方式)

  • 纳税人期末存货怎么结转
  • 出口免税产品如何缴纳附加税
  • 汇算清缴补缴的企业所得税会计分录怎么写
  • 做电商没有进货码怎么办
  • 普票加专票超过30万全交税吗2020
  • 研发费用 会计核算
  • 消防检测需要资质吗?
  • 新会计准则固定资产报废账务处理
  • 企业与政府土地合作开发模式
  • 分支机构如何领购发票
  • 商业保险可以抵扣增值税吗
  • 虚开费用发票入账
  • 代收车船税没有发票能走帐吗
  • 库存商品低价销售违法吗
  • 建筑业在外地预缴了增值税,可以报在本地吗
  • 企业出租房屋交什么税?
  • 我公司开给对方13个点发票,后期我公司怎么抵税
  • 跨地区建筑安装企业个人所得税征收方式申请表
  • 联营和合营的区别共同控制
  • 代扣代缴增值税如何申报抵扣
  • 中药材免税还能抵扣收购发票
  • 个人独资企业简易注销流程及材料
  • 企业税收分为几大类
  • 设计师用windows什么版本
  • 劳务报酬所得包括哪些?与工资薪金所得的区别?
  • 延期报税申请怎么操作
  • win10电脑文件夹打不开
  • 比较常见的病有哪些
  • 错账缴回的银行会计分录
  • 按实际成本结转6日和7日的材料采购成本
  • 塞里雅兰瀑布图片高清
  • VUE -- defineExpose
  • 永续债进什么科目
  • vue中遇到的问题
  • 发行股票溢价计入
  • 基于javaweb是什么意思
  • nvm安装教程
  • expdp/impdp oracle数据泵导入导出
  • nodejs如何与前端交互
  • 个税系统怎么查询已申报个人明细
  • 存货跌价准备科目余额在哪方
  • python搞自动化
  • 福利费是工资的14%,这里工资是税前工资吗
  • 宣传费开票属于什么类别
  • 固定资产丢失如何补办
  • 固定资产清理是资产类的备抵科目吗
  • 持有至到期投资减值准备
  • 员工备用金会计分录
  • 企业筹建期间银行开户要求
  • 货物赔偿款计入什么会计科目
  • 税交多了可以退吗
  • 库存商品品种太多如何算成本
  • 工程物资盘盈为什么冲减在建工程
  • 三方抵账协议做什么科目
  • 建账的大体流程有哪些
  • Windows环境下,在给文件命名时( )
  • shell 加密密码
  • windows隐藏文件名
  • windows预体验版本遇到问题
  • centos 中文
  • win7系统怎么用
  • 乾坤大挪移秘籍图片
  • Win10系统中怎么给图片加备注
  • mac隐藏菜单栏
  • kdeskcore.exe是什么
  • win10系统注册名修改
  • win10怎么将桌面图标变小
  • nodejs 异步
  • mvp设计方案
  • python计算两个数的最大公约数
  • js中数组操作
  • 使用权资产
  • jQuery Checkbox 全选 反选的简单实例
  • bootstrap入门教程
  • jquery技巧
  • 税务登记证信息
  • 各国进口汽车综合税率表
  • 买车险代收车船税合法吗
  • 香港买iphone要交多少税
  • 汉中税务大厅电话是多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设