热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

es8

ES8(ES2017)新功能1.字符串填充。padStart和padEnd,可以通过这两个方法给字符串以padSting开始或结束

ES8(ES2017)新功能

1.字符串填充。

      padStart和padEnd,可以通过这两个方法给字符串以padSting开始或结束,在默认情况下用空  格填充。函数声明如下:

str.padStart(targetLength[, padString])str.padEnd(targetLength[, padString])

参数说明: 第一个参数是targetLength。是我们最终想要得到的字符串的长度。第二个参数是可选的padString,它用于填充源字符串的字符串。

使用示例:

    

2.对象新增原型方法

    Object,values方法和for...in循环所提供的顺序相同的顺序返回给定对象自己的枚举属性性的数组。

Object.values(obj)

返回的是含有对象的属性值的数组

Object.keys(obj) 返回得到的是包含对象的属性名的对象(非新增)

        

Object.entries(obj) 返回的是一个数组。示例如下:

  

Object.getOwnPropertyDescriptors

该方法返回指定对象的所有属性描述符。

  

configurable: 可配置  enumerable:可枚举 writable:可写

3.异步函数

学习异步函数之前,需要深入了解ES6中的promise

Promise对象可以理解为一次将要执行的操作(异步操作),使用了Promise对象之后可以用一种链式调用方式来组织代码。让代码更加直观,Promise.all这样的方法存在,可以让同时执行多个操作变得简单

promise异步的过程

eatSomething(order).then(res =>{ /*pay*/})
.then(res1
=> { /*wait*/ })
.then(res2
=> { /*eat*/ })
.
catch(error =>{ /*error*/})

promise的主要优点就是可以将对列事件以一种直观的方式链接在一起,回调显得简单也更直观。

promise中有两个重要的方法:resolve和reject

function helloWorld (ready) {return new Promise(function (resolve, reject) {if (ready) {resolve("Hello World!");} else {reject("Good bye!");}});
}helloWorld(
true).then(function (message) {alert(message);
},
function (error) {alert(error);
});

说明: resolve 方法可以使Promise对象的状态改变成功,同时传递一个参数用于后续成功的操作。

    reject 方法将Promise对象的状态改变为识别,同时将错误的信息传递到后续错误处理的操作。

promise有三种状态:

             Fulfilld: 成功的状态

     Rejected: 失败的状态

     Pending:既不是Fulfilld也不是Rejected的状态,可以理解为Promise对象实例创建时的初始状态。

helloWorld的例子中then方法就是根据Promise对象的状态来确定执行的操作,resolve时执行第一个函数(onFulfilld),reject时执行第二个函数(onReject)。

【Promise.all】和【Promise.race】

  Promise.all可以接收一个元素为Promise对象的数组作为参数,当这个数组里所有的Promise对象都变为resolve时,该方法才会返回。

var p1 = new Promise( reslove => {setTimeout( () => {reslove('hello')}, 3000)
})
var p2 = new Promise(reslove => {setTimeout( () = > {resolve('world')},1000)
}) Promise.all([p1,p2]).then(result
=> {console.log(result) // ['hello','world']
})

promise.race同样接收一个数组。不同的是只要该数组中的Promise对象的状态发生变化(无论是resolve还是reject都会返回)

我们对promise有了一定的认识,现在来看看es8中新增的关键字async和await

async函数形式

函数声明:
async
function foo () {}

函数表达式:
const foo = async function() {}

方法定义:
const obj = {async foo () {} }

箭头函数
async ()
=> {}

async函数总是返回Promise,async通过return自动将返回值包装成一个prommise对象返回

正常(Fulfill)

// async函数
async function foo () {return 'a'
}
// Promise函数
function foo () {return Promise.reslove('a')
}

异常(Reject) 

// async函数
async function foo () {throw new Error('error')
}
// Promise
function foo () {return Promise.reject(new Error('error'))
}

注: 当返回值本身就是一个Promise对象时,async函数的return并不会对返回值进行二次包装

await总是按顺序执行

使用await之前,需要搞清楚运行机制尤其是在执行顺序上,完全同步的思维也许并不适用于async函数

1.asyn函数和普通函数一样按顺序执行,同时执行在执行await语句时,返回一个Promise对象

2.await可以理解为将async函数挂起,直到等待的Promise被fulfill或者reject,再继续执行之后的代码

3.async函数的返回值和普通的Promise没有区别

await只能影响直接包裹它的async函数。因此在callback函数的await并不会挂起真个async函数执行

参考文献

ECMAScript规范第8版(ES2017)已发布,新功能一览

ES8(ECMAScript 2017) 语言规范发布,附ES6,ES7,ES8规范

使用ES2017 async/await函数的注意点

使用 ES2017 中的 Async(异步) 函数 和 Await(等待)

 

转:https://www.cnblogs.com/fanlina/p/8287101.html



推荐阅读
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
author-avatar
mobiledu2502905163
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有