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



推荐阅读
  • 本文探讨了异步编程的发展历程,从最初的AJAX异步回调到现代的Promise、Generator+Co以及Async/Await等技术。文章详细分析了Promise的工作原理及其源码实现,帮助开发者更好地理解和使用这一重要工具。 ... [详细]
  • 本文探讨了如何使用Scrapy框架构建高效的数据采集系统,以及如何通过异步处理技术提升数据存储的效率。同时,文章还介绍了针对不同网站采用的不同采集策略。 ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • Gradle 是 Android Studio 中默认的构建工具,了解其基本配置对于开发效率的提升至关重要。本文将详细介绍如何在 Gradle 中定义和使用共享变量,以确保项目的一致性和可维护性。 ... [详细]
  • 汇总了2023年7月7日最新的网络安全新闻和技术更新,包括最新的漏洞披露、工具发布及安全事件。 ... [详细]
  • 本文详细介绍如何在SSM(Spring + Spring MVC + MyBatis)框架中实现分页功能。包括分页的基本概念、数据准备、前端分页栏的设计与实现、后端分页逻辑的编写以及最终的测试步骤。 ... [详细]
  • 【MySQL】frm文件解析
    官网说明:http:dev.mysql.comdocinternalsenfrm-file-format.htmlfrm是MySQL表结构定义文件,通常frm文件是不会损坏的,但是如果 ... [详细]
  • 本文探讨了互联网服务提供商(ISP)如何可能篡改或插入用户请求的数据流,并提供了有效的技术手段来防止此类劫持行为,确保网络环境的安全与纯净。 ... [详细]
  • Java虚拟机及其发展历程
    Java虚拟机(JVM)是每个Java开发者日常工作中不可或缺的一部分,但其背后的运作机制却往往显得神秘莫测。本文将探讨Java及其虚拟机的发展历程,帮助读者深入了解这一关键技术。 ... [详细]
  • 在开发过程中,有时需要提供用户创建数据库的功能。本文介绍了如何利用 .NET 和 ADOX 在应用程序中实现创建 Access 数据库,并详细说明了创建数据库及表的具体步骤。 ... [详细]
  • D17:C#设计模式之十六观察者模式(Observer Pattern)【行为型】
    一、引言今天是2017年11月份的最后一天,也就是2017年11月30日,利用今天再写一个模式,争取下个月(也就是12月份& ... [详细]
  • 本文回顾了作者在求职阿里和腾讯实习生过程中,从最初的迷茫到最后成功获得Offer的心路历程。文中不仅分享了个人的面试经历,还提供了宝贵的面试准备建议和技巧。 ... [详细]
  • Asynchronous JavaScript and XML (AJAX) 的流行很大程度上得益于 Google 在其产品如 Google Suggest 和 Google Maps 中的应用。本文将深入探讨 AJAX 在 .NET 环境下的工作原理及其实现方法。 ... [详细]
  • 本文详细介绍了如何在 Ubuntu 14.04 系统上搭建仅使用 CPU 的 Caffe 深度学习框架,包括环境准备、依赖安装及编译过程。 ... [详细]
  • 本文详细介绍了 Redis 中的主要数据类型,包括 String、Hash、List、Set、ZSet、Geo 和 HyperLogLog,并提供了每种类型的基本操作命令和应用场景。 ... [详细]
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社区 版权所有