热门标签 | 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



推荐阅读
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文详细介绍了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. ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细介绍了如何构建一个高效的UI管理系统,集中处理UI页面的打开、关闭、层级管理和页面跳转等问题。通过UIManager统一管理外部切换逻辑,实现功能逻辑分散化和代码复用,支持多人协作开发。 ... [详细]
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社区 版权所有