这篇文章主要介绍“JavaScriptECMAScript6所有新特性怎么用”,在日常操作中,相信很多人在JavaScriptECMAScript6所有新特性怎么用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScriptECMAScript6所有新特性怎么用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!ES2015是改动最大的一个版本,基本上对ES2015之前的所有的内容都做了扩展,大体如下所示:在ES6之前只有一种声明变量的方式,就是使用var
关键字,在ES2015中新增了let
和const
关键字来声明变量与常量,代码如下:同时使用let
和const
关键字声明的变量或者常量是具有块级作用域的,示例代码如下:值得注意的是使用let
或者const
关键字声明的变量不具有变量提升的特性,且存在暂时性死区的特性。在ES2015中允许函数使用默认值,示例代码如下:值得注意的是如果有多个参数时,默认参数必须从后向前使用。在ES2015中新增了箭头函数,这是函数的一种简写形式,示例代码如下:值得注意的是箭头函数的this
是根据执行上下文决定的,内部并不会绑定this
。使用箭头函数时内部并不存在arguments对象,而是采用剩余参数的方式代替,示例代码如下:在ES2015中为函数增加的要给name属性,该属性指向函数的名称,示例代码如下:在ES2015中对数值的扩展主要时为Math
和Number
两个对象增加一些方法,以及二进制和八进制的表示方法。在ES2015中使用0b
或者0B
表示二进制,使用0o
或者0O
表示八进制。示例代码如下:为Number扩展的属性和方法如下:为Math扩展的方法如下:ES2015引入模板字符串,使用反引号(`)定义,模板字符串会保留格式,且可以使用变量,示例代码如下:ES2015还为String和String的实例扩展了一些方法,如下:在ES2015中提供了展开运算符,即…,在数组中使用可以将数组展开,并以逗号分隔,示例代码如下:除此之外,还为Array以及数组提供了一系列方法,来逐个介绍:Array.from()
:将类数组对象或者可迭代对象创建为一个新的数组,示例代码如下:Array.of()
:创建一个具有可变数量参数的新数组实例,示例代码如下:Array.prototype.copyWithin(),浅复制数组的一部分到同一数组中的另一个位置,并返回它,不会改变原数组的长度。示例代码如下:Array.prototype.find()
,根据给定的回调函数,找到匹配的第一个元素,找不到返回undefined,示例代码如下:Array.prototype.findIndex()
,根据给定的回调函数,找到匹配的第一个元素的索引,找不到返回-1,示例代码如下:Array.prototype.fill()
,将给定值填充数组,示例代码如下:Array.prototype.keys()
,返回一个可迭代的对象,其内容为数组的key,示例代码如下:Array.prototype.values()
,返回一个可迭代的对象,其内容为数组的value,示例代码如下:Array.prototype.entries()
,返回一个可迭代的对象,其内容是一个数组,索引0
为原数组的元素,1
为原数组该位置的值,示例代码如下:ES2015中允许对象的属性名和属性值一致时可以只写属性名,示例代码如下:还有就是在定义对象时,允许使用[]包裹表达式作为属性名,示例代码如下:Object.is()
:用于比较两个值是否相等,用于解决NaN ≠= NaN,+0 === -0的问题,示例代码如下:Object.assign()
:将所有可枚举属性的值从一个或多个源对象复制到目标对象,并返回目标对象,示例代码如下:Object.getPrototypeOf()
:获取原型对象;Object.setPrototypeOf()
:设置原型对象。在ES2015中提出了类的概念,在语法的层面上有了类,示例代码如下:在ES2015中提出ESModel模块化规范,这是第一个官方层面的模块化规范,在这个规范中允许我们使用export导出模块,使用import引入模块,示例代码如下:ES2015新增了解构赋值的语法,允许我们使用按照一定的模式,在数组或者对象中提取指定的值,示例代码如下:Symbol是ES2015中新增的一种数据类型,通过Symbol()
方法创建,可以传递一个字符串作为参数,用于描述该Symbol;通过Symbol()方法创建的symbol值都是唯一的,示例代码如下:Symbol还有一系列属性和方法这里就不作介绍了。Promise是ES2015中提供的一个异步解决方案,解决了回调地狱的问题。通过Promise()
构造函数可以创建一个promise对象,每一个Promise对象都具有以下几种状态:pending: 初始状态,既不是成功,也不是失败状态。resolved: 意味着操作成功完成。rejected: 意味着操作失败。状态的切换只有两种,分别是:pending→resolvedpending→resolved一旦状态发生改变,就不会再次改变Promise
实例中存在要给then
方法,允许我们在Promise
实例中链式调用,每个then
方法还会返回一个Promise
实例,如下图所示:示例代码如下:有关Promise的一些方法如下:Promise.prototype.then()
:它最多需要有两个参数:Promise的成功和失败情况的回调函数;Promise.prototype.catch()
:等于then
方法的第二个参数;Promise.all()
:将多个实例包装成一个新实例,返回全部实例状态变更后的结果数组(齐变更再返回)Promise.race()
:将多个实例包装成一个新实例,返回全部实例状态优先变更后的结果(先变更先返回)Promise.resolve()
:将对象转为Promise对象(等价于new Promise(resolve => resolve())
)Promise.reject()
:将对象转为状态为rejected
的Promise对象(等价于new Promise((resolve, reject) => reject())
)Iterator即迭代器,它是一种接口,为各种不同的数据结构提供了统一的访问机制,换句话说,只要有任何数据结构部署了迭代接口,就可以使用统一的方式的来遍历它。实现可迭代接口的数据结构,一般都自身实现或继承了以Symbol.iterator
属性的,就属于可迭代对象。Symbol.iterator
属性本身是一个函数,就是当前数据结构默认的遍历器生成函数。一个包含next()
方法的对象,才可以称为一个迭代对象。next()
对象的会有返回一个对象,对象中包含两个值,如下所示:value
:迭代器返回的任何JavaScript
值。done
为true
时可省略。done
:一个布尔值,为false
时表示迭代未停止,为true
时立即停止迭代器,且可以省略value
的值。JavaScript原生提供的迭代器接口如下图所示:现在我们为obj来实现一个迭代器,代码如下:我们在next()
方法中添加了一个打印,为了验证迭代器执行了,最终的运行结果为迭代器执行了Generator是ES2015中提供的一种异步编程解决方案,定义Generator函数在function
关键字和函数名中间使用*
星号,函数内部使用yield
关键字定义不同的状态。示例代码如下:Proxy对象用于创建一个代理对象,从而实现基本操作的拦截和自定义,基本操作包含13种,如下表所示:Vue3就是基于Proxy
进行编写的,下面这段代码展示了Proxy
对象的使用:
上面的代码就利用set方法进行数据绑定,如果对象发生改变,就自动更新我们的DOM。Reflect是ECMAScript2015提供的一个对象,它提供了一些拦截JavaScript操作的静态方法,这些方法与Proxy中的handlers
中的方法一致。Reflect并不是一个构造函数,也就是说它不能够被实例化。Proxy
对象中的每一个拦截操作(例如:get
、delete
等),内部都对应的调用了Reflect
的方法。它提供的静态方法与Proxy中的handlers
中的方法名称都一致,具体如下:Set
、Map
、WeakSet
、WeakMap
是ES2015中新增的几个对象:Set
和WeakSet
与数组类似,准确的它他们是集合,这两者的区别就是Set
可以存储任何数据类型,而WeakSet
只能存储对象的引用,而且是弱引用;Set对象在实际开发中最常见的就是实现数据去重,示例代码如下:Map
和WeakMap
与对象类似,存储方式是键值对形式的,这两者的区别Map
的键值对都是可以是任意的而WeakMap
键必须是对象的引用而值可以是任意类型的。ES2016发布的新特性比较少,主要就两个新特性,如下图所示:ES2016中新增指数**
,也叫幂运算符,与Math.pow()有着一样的功能,示例代码如下:在ES2016中在数组原型上增加了includes()
方法,该方法用于判断一个数组中是否包含指定的值,返回一个布尔值,示例代码如下:值得注意的是使用includes()
时NaN
与NaN
、+0
与-0
是相等的。Promise的出现虽然解决了回调地狱的问题,但是如果链式调用特别多的话可读性还是会变差,在ES2017中新增了 async/await语法糖解决了这个问题。Promise的写法如下:如果下一个Promise依赖于上一个,这种链式调用就会非常的长,现在我们用 async/await语法糖改写一下:可以看到,我们可以利用 async/await语法糖将Promise改写为平级的写法。ES2017中新增了Atomics对象,该对象提供了一系列静态方法用于操作SharedArrayBuffer和ArrayBuffer对象,该对象并不能使用new
关键字进行实例化,仅仅提供了一些静态的属性和方法在ES2017中为Object扩展了三个静态方法,如下所示:Object.values()
:返回一个给定对象自身的所有可枚举属性值的数组;Object.entries()
:返回一个给定对象自身可枚举属性的键值对数组;Object.getOwnPropertyDescriptors()
:返回给定对象所有自有属性的属性描述符。在ES2017中允许我们在函数参数列表的最后面添加逗号,这个小特性非常的有用,因为为尾逗号的更新的时候仅仅需要改动一行代码,如果不适用尾逗号则是改动两行代码。实例代码如下:如果存在尾逗号,只需要在最后面添加一行就好;如果不存在则需要在后面添加要给逗号,然后在添加一行。这在版本管理中就改动了两行,而不是一行。在ES2017中为字符串新增了两个实例方法,分别是:padStart()
:在字符串开头填充空格;padEnd()
:在字符串结尾填充空格;示例代码如下:在ES2018中新增了for await...of
语句,该用于可以遍历异步可迭代对象,示例代码如下:在ES2018中,对正则表达式进行了如下扩展:正则表达式分组命名:在ES2018之前,我们无法对正则表达式中的分组命名,在ES2018中引入了该特性,该特性既方便了正则的阅读又方便了引用,示例代码如下:s修饰符/dotALl模式:新增的s修饰符允许使用.
匹配任意单个字符,****属性表明是否在正则表达式中一起使用”s
“修饰符。反向断言:ES2018之前仅存在正向断言,而ES2018中新增了反向断言和反向否定断言。ES2015中新增数组的展开运算符,在ES2018中将这一特性加入到了对象中,示例代码如下:finally()
方法会返回一个Promise
对象,当promise的状态变更,不管是变成rejected
或者fulfilled
,最终都会执行finally()
的回调。示例代码如下:在ES2019中优化了以下两个内容:Function.prototype.toString()
:返回的函数体包含注释与空格;try...catch
:语句中的catch
允许不使用参数,示例代码如下:String.prototype.trimStart
:用于去除字符串左边的空格;String.prototype.trimLeft
:它是trimStart
的别名String.prototype.trimEnd
:用于去除字符串右边的空格;String.prototype.trimRight
:它是trimEnd
的别名在ES2019中扩展了两个数组方法,分别是:Array.prototype.flat()
:该方法会按照一个可指定的深度递归遍历数组,并将所有元素与遍历到的子数组中的元素合并为一个新数组返回;简单的说就是实现数组的扁平化。Array.prototype.flatMap()
:该方法映射且扁平化数组,返回新数组(只能展开一层数组)。ES2019中新增的Object.fromEntries()
方法把键值对列表转换为一个对象,是Object.entries()
方法的反操作,示例代码如下:description
是一个只读属性,它会返回创建Symbol对象时的那个可选的描述字符串。模块化在ES2020中加入了动态导入,也就是我们需要该模块的时候才会进行加载,这可以减少开销和页面加载时间,示例代码如下:动态导入使用import()
方法,它返回一个Promise。在ES2020中,还为import
增加一个meta
对象,该对象给JavaScript模块暴露了特定上下文的元数据属性的对象。BigInt的出现时解决JavaScript中允许的最大数字是2**53-1
的问题,BigInt
可以表示任意大的整数。ES2020中引入globalThis
,它是对全局对象的引入,在Node是的全局对象是Global
,而浏览器环境是Window
;如下代码展示的在有没有GlobalThis
的区别:空值合并运算符是由两个问号来表示,该运算符也是一个逻辑运算符,该运算符与逻辑或运算符类似。其计算规则为,只要左运算元为null
或者undefined
,则返回右运算元,否则返回左运算元。而逻辑或运算符只有左运算元转换为boolean
类型后为false
,就返回右运算元。示例代码如下:该运算符用于为没有值的变量赋值很有用,例如:如果这个数没有值,就为其赋值,否则不赋值,示例代码如下:值得注意的是空值合并运算符与逻辑与和逻辑或不能同时使用,否则会抛出异常,解决方案是通过使用()
来表明优先级可选链操作符用于读取某对象链下深处属性的值,使用这个操作符不必验证对象下的每个属性必须存在,例如我们想要访问A.a.b
这个属性时,我们首先需要确保A
存在,然后需要确保A.a
存在,才可以访问A.a.b
这个属性,不然就会报错。使用可选链操作符就不会出现这样的问题,当我们访问某个属性时,只要有一处不存在,就会返回undefind
,不会报错。可选链操作符也可用于对象下方法的调用,示例代码如下:Promise.allSettled()
方法返回一个在所有给定的 promise 都已经resolved或rejected后的 promise,并带有一个对象数组,每个对象表示对应的 promise 结果。replaceAll()
方法返回一个新字符串,新字符串的内容是经过替换的,实例代码如下:严格意义上讲数值分隔符(_
)并不属于一个运算符,其作用就是使数字更加利于阅读,例如下面的代码这个符号仅仅起到了便于阅读的目的,有与没有的结果并不影响,看下面的代码ES2021中新增的WeakRef
对象允许您保留对另一个对象的弱引用,而不会阻止被弱引用对象被GC回收。ES2021中新增的Promise.any()
方法,它接受的参数和与promise.all()
是一致的,唯一不同的是,Promise.any()
方法接受的可迭代对象中没有一个promise成功(即所有的promises都失败/拒绝),就返回一个失败的promise和AggregateError类型的实例。ES2021中新增了一些赋值运算符,具体如下:&&=
||=
??=
实际上它与普通的赋值运算符一致,示例代码如下:在ES2022中允许我们并不在constructor
中定义类的成员,示例代码如下:如果成员只声明不初始化它的默认值是undefined。在ES2022中允许我们使用#
开头命名免费云主机、域名的变量作为类的私有成员,示例代码如下:在ES2022中新增了允许在顶层使用await
,在顶层可以不适用async
函数进行包裹,示例代码如下:Object.hasOwn()
方法用于判断某个对象上是否具有某个属性,示例代码如下:ES2022中新增的at()
方法,它的作用是获取数组中的某个成员,它的参数是数组的索引,与直接使用索引的方式不同,它允许我们传递负值,等同于从后面倒数,示例代码如下:正则表达式增加了一个/d
修饰符,当使用正则表达式的exec()
方法时,如果有/d
修饰符,那么结果会多返回一个indices属性,用来表示匹配的结果的在原字符串中的起始index值。示例代码如下:到此,关于“JavaScriptECMAScript6所有新特性怎么用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注云技术网站,小编会继续努力为大家带来更多实用的文章!
这篇文章主要介绍了Nodejs中怎么自定义CommonJS模块的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Nodejs中怎么自定义CommonJS模块文章都会有所收获,下面我们一起来看看吧。 JavaScript 是一个强大面向…