位置: 编程技术 - 正文

ES6的新特性概览(es6十大特性)

编辑:rootadmin

推荐整理分享ES6的新特性概览(es6十大特性),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:es6特性总结,es6十大特性,es6新特性promise,es6新特性及作用,es6十大特性,es6新特性promise,es6新增了哪些特性,es6最新特性,内容如对您有帮助,希望把文章链接给更多的朋友!

Nick Justice是GitHub开发者计划的一员。早在ES6语言标准发布之前,他就借助像Babel这样的转译器以及最新版本的浏览器在自己的项目中使用ES6特性。他认为,ES6的新特性将极大地改变JavaScript的编写方式。

ES6(ECMAScript 6)是即将到来的新版本JavaScript语言的标准,代号harmony(和谐之意,显然没有跟上我国的步伐,我们已经进入中国梦版本了)。上一次标准的制订还是年出台的ES5。目前ES6的标准化工作正在进行中,预计会在年月份放出正式敲定的版本。但大部分标准已经就绪,且各浏览器对ES6的支持也正在实现中。

技术虽然发展太快,但是我们不停下学习的步伐,就不会被新技术淘汰,下面我们一起来学习es6的新特征吧。

箭头操作符

如果你会C#或者Java,你肯定知道lambda表达式,ES6中新增的箭头操作符=>便有异曲同工之妙。它简化了函数的书写。操作符左边为输入的参数,而右边则是进行的操作以及返回的值Inputs=>outputs。

我们知道在JS中回调是经常的事,而一般回调又以匿名函数的形式出现,每次都需要写一个function,甚是繁琐。当引入箭头操作符后可以方便地写回调了。请看下面的例子:

类的支持

ES6中添加了对类的支持,引入了class关 键字(其实class在JavaScript中一直是保留字,目的就是考虑到可能在以后的新版本中会用到,现在终于派上用场了)。JS本身就是面向对象 的,ES6中提供的类实际上只是JS原型模式的包装。现在提供原生的class支持后,对象的创建,继承更加直观了,并且父类方法的调用,实例化,静态方 法和构造函数等概念都更加形象化。

下面代码展示了类在ES6中的使用:

增强的对象字面量

对象字面量被增强了,写法更加简洁与灵活,同时在定义对象的时候能够做的事情更多了。具体表现在:

1.可以在对象字面量里面定义原型

2.定义方法可以不用function关键字

3.直接调用父类方法

这样一来,对象字面量与前面提到的类概念更加吻合,在编写面向对象的JavaScript时更加轻松方便了。

字符串模板

字符串模板相对简单易懂些。ES6中允许使用反引号 ` 来创建字符串,此种方法创建的字符串里面可以包含由美元符号加花括号包裹的变量 ${vraible}。如果你使用过像C#等后端强类型语言的话,对此功能应该不会陌生。

解构

自动解析数组或对象中的值。比如若一个函数要返回多个值,常规的做法是返回一个对象,将每个值做为这个对象的属性返回。但在ES6中,利用解构这一特性,可以直接返回一个数组,然后数组中的值会自动被解析到对应接收该值的变量中。

参数默认值,不定参数,拓展参数

默认参数值

现在可以在定义函数的时候指定参数的默认值了,而不用像以前那样通过逻辑或操作符来达到目的了。

ES6的新特性概览(es6十大特性)

不定参数

不定参数是在函数中使用命名参数同时接收不定数量的未命名参数。这只是一种语法糖,在以前的JavaScript代码中我们可以通过arguments变量来达到这一目的。不定参数的格式是三个句点后跟代表所有不定参数的变量名。

比如下面这个例子中,…x代表了所有传入add函数的参数。

拓展参数

拓展参数则是另一种形式的语法糖,它允许传递数组或者类数组直接做为函数的参数而不用通过apply。

let与const 关键字

可以把let看成var,只是它定义的变量被限定在了特定范围内才能使用,而离开这个范围则无效。const则很直观,用来定义常量,即无法被更改值的变量。

for of 值遍历

我们都知道for in循环用于遍历数组,类数组或对象,ES6中新引入的for of循环功能相似,不同的是每次循环它提供的不是序号而是值。

iterator, generator

1.iterator: 它是这么一个对象,拥有一个next方法,这个方法返回一个对象{done,value},这个对象包含两个属性,一个布尔类型的done和包含任意值的value

2.iterable: 这是这么一个对象,拥有一个obj[@@iterator]方法,这个方法返回一个iterator

3.generator: 它是一种特殊的iterator。反的next方法可以接收一个参数并且返回值取决与它的构造函数(generator function)。generator同时拥有一个throw方法

4.generator函数: 即generator的构造函数。此函数内可以使用yield关键字。在yield出现的地方可以通过generator的next或throw方法向外界传递值。generator 函数是通过function*来声明的

5.yield关键字:它可以暂停函数的执行,随后可以再进进入函数继续执行

模块

在ES6标准中,JavaScript原生支持module了。这种将JS代码分割成不同功能的小块进行模块化的概念是在一些三方规范中流行起来的,比如CommonJS和AMD模式。

将不同功能的代码分别写在不同文件中,各模块只需导出公共接口部分,然后通过模块的导入的方式可以在其他地方使用。

这些是新加的集合类型,提供了更加方便的获取属性值的方法,不用像以前一样用hasOwnProperty来检查某个属性是属于原型链上的呢还是当前对象的。同时,在进行属性值添加与获取时有专门的get,set方法。

上面代码我已加了注释,这里进一步解释。对于处理程序,是在被侦听的对象身上发生了相应事件之后,处理程序里面的方法就会被调用,上面例子中我们设置了set的处理函数,表明,如果我们侦听的对象的属性被更改,也就是被set了,那这个处理程序就会被调用,同时通过参数能够得知是哪个属性被更改,更改为了什么值。

Symbols

我们知道对象其实是键值对的集合,而键通常来说是字符串。而现在除了字符串外,我们还可以用symbol这种值来做为对象的键。Symbol是一种 基本类型,像数字,字符串还有布尔一样,它不是一个对象。Symbol 通过调用symbol函数产生,它接收一个可选的名字参数,该函数返回的symbol是唯一的。之后就可以用这个返回值做为对象的键了。Symbol还可以用来创建私有属性,外部无法直接访问由symbol做为键的属性值。

有关ES6的新特性就给大家介绍这么多,希望对大家有所帮助!

ES6中非常实用的新特性介绍 ECMAScript6离我们越来越近了,作为它最重要的方言,Javascript也即将迎来语法上的重大变革,InfoQ特开设深入浅出ES6专栏,来看一下ES6将给我们带来哪些新

JavaScript File分段上传 HTMLformmethod="POST"name="form"action="/mupload/upload/"enctype="multipart/form-data"inputtype='hidden'name='csrfmiddlewaretoken'value=''/inputid='file'type='file'name='file'onchange=""/inputid='butt

TypeScript Type Innference(类型判断) TypeScript是微软开发的JavaScript的超集,TypeScript兼容JavaScript,可以载入JavaScript代码然后运行。TypeScript与JavaScript相比进步的地方包括:加入注释,让编译

标签: es6十大特性

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

上一篇:JavaScript字符串常用的方法(JAVAscript字符串类型单引号和双引号意一样吗)

下一篇:ES6中非常实用的新特性介绍(es6新方法有哪些)

  • 递延所得税负债是什么科目
  • 营改增后土地增值税应税收入的确认
  • 小规模纳税人税率2023年是多少
  • 土地增值税怎么计算
  • 出口不退税进项税如何处理
  • 运输服务有3%的税率吗
  • 幼儿园属于小型幼儿吗
  • 公司打印银行回单和对账单
  • 结转损益类费用科目的余额
  • 计算错误多缴税怎么处理
  • 土地增值税清算规程实施细则
  • 管理费用 结转
  • 港币转人民币怎么转账
  • 经营租赁融资租赁增值税税率
  • 取得转账支票后该如何处理
  • 工会经费应该计入人工成本吗
  • 滴滴 增值税
  • 为什么利润表的财务费用与利息费用逻辑不对
  • 发票校验码后六位图解
  • 发了工资了
  • 金税盘怎么增加复核人
  • 需要会计报表的人
  • 小规模纳税人出售使用过固定资产
  • 冲减预付款
  • 实际投资收益率等于什么
  • 苹果手机最贵的软件是哪个
  • php中的类型提示是什么
  • 房地产佣金手续费财务处理
  • 供热企业税收优惠政策
  • php文件怎么创建
  • 全局函数使用
  • 建行e信通怎么提现怎么操作
  • Node.js安装过程
  • 深度学习实战(十):使用 PyTorch 进行 3D 医学图像分割
  • 瀑布流实现方式
  • Python运算符的优先级别
  • ps里的钢笔工具
  • 清算时实收资本需要做收入吗为什么
  • 应发工资包含
  • 生产部门包括
  • 分公司财务负责人要求
  • 解决mysql数据库异常断电
  • 税控盘维护费全额抵扣分录
  • 装修公司让客户承担税费是否合理
  • 印花税不足一元免征吗
  • 公司报销专用发票
  • 临时工工资会计凭证
  • 开专票需要什么条件呢怎么开
  • 一个企业只有收入怎么办
  • 什么是资本公积,举例说明
  • 职工福利费核算哪些内容
  • mac安装mysql的两种方法(含配置)
  • sql高级写法
  • oracle基础知识
  • win7开机提示由于启动计算机时出现页面文件
  • solaris 11.4
  • ubuntu系统如何
  • smOutlookPack.exe - smOutlookPack是什么进程 什么文件
  • uca1
  • GHOST XP 安装教程
  • win10系统光驱
  • rrpcsb.exe - rrpcsb是什么进程 有什么用
  • yum update upgrade
  • Linux中systemd target命令使用详解
  • win10系统经常弹出广告页面怎么解决
  • Win10预览版桌面图标和任务栏不翼而飞怎么办?
  • Win10预览版拆弹
  • javascript 基础
  • js内存条
  • android drawable 圆角锯齿
  • 基于Python的图书推荐系统
  • jQuery解析XML 详解及方法总结
  • 如何用android
  • 如何查询以前月份发票超限量的申请
  • 税收缴款书税务收现专用的开票人是谁
  • 珠海的教育水平在全省的排名
  • 国税总局北京税务局
  • 公司有房屋租赁许可证吗
  • 电话号码公开是什么意思
  • 什么是增值税税率是多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设