返回顶部
首页 > 资讯 > 前端开发 > html >ES2019中非常有用的功能有那几种
  • 296
分享到

ES2019中非常有用的功能有那几种

2024-04-02 19:04:59 296人浏览 八月长安
摘要

这篇文章给大家介绍ES2019中非常有用的功能有那几种,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。String.prototype.trimStart()和String.protot

这篇文章给大家介绍ES2019中非常有用的功能有那几种,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

ES2019中非常有用的功能有那几种

String.prototype.trimStart()和String.prototype.trimEnd()

有时我们在处理字符串时需要处理多余的空格。ES2020  增加了两个功能:.trimStart()和 trimEnd() 方法可以帮你处理这些琐事。

它们都可以帮助你修剪或删除给定字符串中的空格。trimStart()  删除字符串开头的所有空格。trimEnd()将删除字符串末尾的所有空格。不过要是想去除两边的空格呢?

有两个选择。第一种是同时使用这两个 ES2019 功能。第二个是使用另一个字符串方法 trim()。两种方式都能给你想要的结果。

// String.prototype.trimStart() 例子: // 处理不带空格的字符串: 'javascript'.trimStart() // Output: //'JavaScript'  // 处理以空格开头的字符串: ' JavaScript'.trimStart() // Output: //'JavaScript'  // 两边都留有空格的字符串 ' JavaScript '.trimStart() // Output: //'JavaScript '  // 以空格结尾的字符串 'JavaScript '.trimStart() // Output: //'JavaScript '   // String.prototype.trimEnd() 例子: // 处理不带空格的字符串: 'JavaScript'.trimEnd() // Output: //'JavaScript'  // 处理以空格开头的字符串: ' JavaScript'.trimEnd() // Output: //' JavaScript'  // 两边都留有空格的字符串 ' JavaScript '.trimEnd() // Output: //' JavaScript'  // 以空格结尾的字符串 'JavaScript '.trimEnd() // Output: //'JavaScript'

Function.prototype.toString()

函数的 toString()  方法已经存在了一段时间。它的作用是使你可以打印函数的代码。ES2019 的不同之处在于它处理注释和特殊字符(例如空格)的方式。

过去,toString() 方法删除了注释和空格。所以该函数的打印版本可能看起来与原始代码不一样。ES2019  的不会再发生这种情况。它返回的值将会与原始值匹配,包括注释和特殊字符。

// ES2019 之前: function myFunc() {    }  myFunc.toString() // Output: // "function myFunc() {}"   // ES2019: function myFunc() {    }  myFunc.toString() // Output: // "function myFunc() { //    // }"

Array.prototype.flat()和Array.prototype.flatMap()

数组是 JavaScript  的基本组成部分之一。它们有时会引起很多问题。当你必须要处理多维数组时尤其如此。甚至将多维数组转换为一维这样看似简单的任务也可能很困难。

好消息是,ES2019 的两个功能使这种操作变得更容易。第一个是 flat()  方法。在多维数组上使用时,它将转换为一维。默认情况下,flat()只会将数组展平一级。

但是页可以指定级数,并在调用时作为参数传递。如果不确定需要多少级,也可以使用 Infinity。

// 创建一个数组: const myArray = ['JavaScript', ['C', 'c++', ['Assembly', ['Bytecode']]]]  // 展平一级: let myFlatArray = myArray.flat(1)  // 输出: console.log(myFlatArray) // Output: // [ 'JavaScript', 'C', 'C++', [ 'Assembly', [ 'Bytecode' ] ] ]  // 用参数 Infinity 展平: let myInfiniteFlatArray = myArray.flat(Infinity)  // 输出: console.log(myInfiniteFlatArray) // Output: // [ 'JavaScript', 'C', 'C++', 'Assembly', 'Bytecode' ]

Array.prototype.flatMap()

除了 flat() 方法之外,还有 flatMap()。可以把它看作是 flat() 的高级版本。区别在于 flatMap() 方法把 flat() 与  map() 结合了起来。在展平数组时,可以调用回调函数。

这样就可以在展平过程中使用原始数组中的每个元素。当在对数组进行展平操作的同时又要修改内容时很方便。

// 创建数组: const myArray = ['One Word', 'Two words', 'Three words']  // 用 map() 将数组中的所有字符串拆分为单词: // 注意:这将会创建多维数组。 const myMappedWordArray = myArray.map(str => str.split(' '))  console.log(myMappedWordArray) // Output: // [ [ 'One', 'word' ], [ 'Two', 'words' ], [ 'Three', 'words' ] ]   // flatMap() 的例子: const myArray = ['One word', 'Two words', 'Three words']  // 用 map() 将数组中的所有字符串拆分为单词: // 注意:这将会创建多维数组。 const myFlatWordArray = myArray.flatMap(str => str.split(' '))  console.log(myFlatWordArray) // Output: // [ 'One', 'word', 'Two', 'words', 'Three', 'words' ]

Object.fromEntries()

当需要把某个对象转换为数组时,可以用 entries() 来完成。但是想要反向操作的话就困难了。ES2019  提供了 fromEntries() 来轻松解决这个问题。

这个方法的作用很简单。它需要键值对的可迭代形式,例如数组或 Map,然后将其转换为对象。

// 把数组转换为对象: // 创建数组: const myArray = [['name', 'Joe'], ['age', 33], ['favoriteLanguage', 'JavaScript']] const myObj = Object.fromEntries(myArray) console.log(myObj) // Output: // { //   name: 'Joe', //   age: 33, //   favoriteLanguage: 'JavaScript' // }   // 把 Map 转换为对象: // 创建 map: const myMap = new Map(   [['name', 'Spike'], ['species', 'dog'], ['age', 3]] ) const myObj = Object.fromEntries(myMap) console.log(myObj) // Output: // { //   name: 'Spike', //   species: 'dog', //   age: 3 // }

可选的 catch 绑定

以前使用 try ... catch 时,还必须使用绑定。即使没有使用该异常,你也必须将其作为参数传递。在 ES2019  种,如果不想使用该异常,则可以使用不带参数的 catch 块。

// ES2019 之前: try {   // Do something. } catch (e) {  //忽略必需的e参数     //如果你不想用它,也应该保留。 }  // ES2019: try {   // Do something. } catch {   // 不需要添加任何参数 }

格式正确的 JSON.stringify()

过去,当对包含特定字符的东西使用 JSON.stringify() 时,会得到格式不正确的 Unicode  字符串。从 U+D800到 U+DFFF 的编码段会变成 “�”。更糟的是没办法把这些错误的字符变回原样。

ES2019 修复了 jsON.stringify() 方法。现在能够对那些有问题的代码段进行分类,并且可以将它们转换回其原始表示形式。

Symbol.prototype.description

符号是在 ES2015(es6)中引入的新数据类型。它们通常用于标识对象属性。ES2019 增加了  description 属性。这个属性是只读的,无法更改它的值。它用来返回给定符号的描述。

要牢记两点。首先,创建符号时描述不是必须的,而是可选的。所以当你尝试访问 description 时,可能会得到除 undefined  之外的任何信息。如果你尝试访问不带描述的符号描述,则会得到 undefined(未定义)信息。

第二点是 description 是对符号本身的描述。它不是符号的标识符。这意味着你不能使用现有的描述(即 description  属性的值)来访问现有的符号。它只是为了更容易识别正在你正在使用的符号。

说明:创建新的符号时,可以通过将一些字符串作为参数传递给 Symbol() 对象来添加描述。如果留空,description 将会是  undefined。

// 创建带有描述的 Symbol: // 创建 Symbol 并添加描述: //注意:描述是"My first symbol." const mySymbol = Symbol('My first symbol.')  // 输出 description 属性的值: console.log(mySymbol.description) // Output: // 'My first symbol.'   // 读取不存在的 Symbol: console.log(Symbol().description) // Output: // undefined   // 读取定义为空字符串的描述: console.log(Symbol('').description) // Output: // ''

Symbol.prototype.toString()

toString() 方法提供了另一种读取符号描述的方式。它的缺点是在返回的字符串中还包含 Symbol()。另一个区别是 toString()  方法永远不会返回不存在的undefined描述。

使用 description 的另一个原因是:如果你有一个没有说明的 Symbol 并用了 toString() 方法,仍将得到 Symbol()  部分。如果描述为空字符串,也将获得此信息。这样就基本上不可能区分不存在的描述和用作描述的空字符串。

// 创建带有描述的 Symbol: const mySymbol = Symbol('REAMDE.')  // 输出 description 属性的值: console.log(mySymbol.toString()) // Output: // 'Symbol(REAMDE.)'  // 读取不存在的 Symbol: console.log(Symbol().toString()) // Output: // 'Symbol()'   // 读取定义为空字符串的描述: console.log(Symbol('').toString()) // Output: // 'Symbol()'

关于ES2019中非常有用的功能有那几种就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: ES2019中非常有用的功能有那几种

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

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

猜你喜欢
  • ES2019中非常有用的功能有那几种
    这篇文章给大家介绍ES2019中非常有用的功能有那几种,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。String.prototype.trimStart()和String.protot...
    99+
    2024-04-02
  • ES2019中值得收藏的功能有哪些
    这篇文章主要介绍了ES2019中值得收藏的功能有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。ES2019 规范是对 JavaScript的小规模扩展,但仍带来了一些有趣...
    99+
    2023-06-14
  • 总结几段非常有用的脚本
    本篇内容主要讲解“总结几段非常有用的脚本”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“总结几段非常有用的脚本”吧!一、在网络硬件故障或网络故障断开时发送警告 复制代码 代码如下:str...
    99+
    2023-06-08
  • php中常用的表达式有哪几种
    php 中常用的表达式包括:算术表达式:用于数学运算比较表达式:比较两个值逻辑表达式:组合逻辑条件条件表达式:简化的 if-else 语句数组表达式:创建数组字符串表达式:创建字符串 ...
    99+
    2024-04-29
  • springmvc常用的注解有哪几种
    Spring MVC常用的注解有以下几种: @Controller:将类声明为控制器类,用于处理HTTP请求。 @Reque...
    99+
    2024-02-29
    springmvc
  • 数据结构的链表有那几种类型
    这篇文章主要介绍“数据结构的链表有那几种类型”,在日常操作中,相信很多人在数据结构的链表有那几种类型问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”数据结构的链表有那几种类型”...
    99+
    2024-04-02
  • Go语言HTTPServer开发的有那几种方式
    这篇文章主要介绍“Go语言HTTPServer开发的有那几种方式”,在日常操作中,相信很多人在Go语言HTTPServer开发的有那几种方式问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Go语言HTTPSer...
    99+
    2023-06-25
  • java中常见的几种锁有哪些
    公平锁/非公平锁公平锁是指多个线程按照申请锁的顺序来获取锁。非公平锁是指多个线程获取锁的顺序,并不是按照申请锁的顺序,有可能后申请的线程比先申请的线程优先获取锁,有可能,会造成优先级反转或者饥饿现象。独享锁/共享锁独享锁是指该锁一次只能被一...
    99+
    2017-11-14
    java入门 java 常见
  • rem适配的有几种常用封装
    这篇文章给大家分享的是有关rem适配的有几种常用封装的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、rem1.js第一种方法考虑了m端屏幕旋转的问题.对兼容性做出了一定的处理,具体看代码.export ...
    99+
    2023-06-08
  • seajs中常用的功能有哪些
    这篇文章给大家分享的是有关seajs中常用的功能有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体如下:1. seajs.configseajs.config({ &nbs...
    99+
    2024-04-02
  • plc常用的编程语言有哪几种
    PLC(可编程逻辑控制器)常用的编程语言有以下几种:1. Ladder Diagram(LD):梯形图是最常见和最常用的PLC编程语...
    99+
    2023-10-12
    plc
  • 常用的android加密方式有哪几种
    常用的Android加密方式有以下几种:1. 文件加密:通过对文件进行加密,确保文件内容的机密性,常见的文件加密算法有AES(Adv...
    99+
    2023-10-18
    android
  • 常用的golang并发模型有哪几种
    常用的Golang并发模型有以下几种: 传统的多线程模型:基于线程和锁的并发模型,通过创建多个线程来处理并发任务,并使用锁来保护...
    99+
    2024-02-29
    golang
  • JAVA常见的运行异常有哪几种
    在Java中,常见的运行时异常有以下几种: NullPointerException(空指针异常):当程序试图访问一个空对象的属性...
    99+
    2024-02-29
    JAVA
  • 云服务器有哪几种服务模式的功能
    云服务器可以提供以下服务模式的功能: IaaS(基础设施即服务):提供计算(例如服务器)、存储、网络、安全等IaaS服务,同时也支持SaaS(软件即服务)服务。这种服务模式下的云服务器通常是由一个云计算基础设施提供,如公有云、私有云等。...
    99+
    2023-10-26
    几种 模式 功能
  • Java的引用有几种
    这篇文章主要讲解了“Java的引用有几种”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java的引用有几种”吧!  1.强引用  如果一个对象具有强引用,那就 类似于必不可少的生活用品,垃圾...
    99+
    2023-06-02
  • MySQL表关联的常用方式有哪几种
    本文主要给大家介绍MySQL表关联的常用方式有哪几种,文章内容都是笔者用心摘选和编辑的,具有一定的针对性,对大家的参考意义还是比较大的,下面跟笔者一起了解下MySQL表关联的常用方式有哪几种吧。建表及插入数...
    99+
    2024-04-02
  • jQuery常用的功能有哪些
    本篇内容介绍了“jQuery常用的功能有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!下面这些简单的小...
    99+
    2024-04-02
  • CSS选择器常见的有哪几种
    这篇文章将为大家详细讲解有关CSS选择器常见的有哪几种,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 css中选择器有:1、简单选择器;2、属...
    99+
    2024-04-02
  • 常见的web服务器有哪几种
    常见的Web服务器有Apache、Nginx、IIS等。它们的优势如下:1. Apache:Apache是最流行的Web服务器之一,...
    99+
    2023-06-13
    web服务器 服务器
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作