ES6 async await

Posted rainscoco

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ES6 async await相关的知识,希望对你有一定的参考价值。

  1 <!DOCTYPE html>
  2 <html lang="en">
  3 <head>
  4     <meta charset="UTF-8">
  5     <title>async-await</title>
  6 </head>
  7 <body>
  8     <h3>ES6 async 函数用法</h3>
  9 
 10     <script>
 11 
 12         window.onload = function() {
 13 
 14             // 例-1: 继发异步
 15             async function f() {
 16                 try {
 17                     let a = await new Promise((resolve, reject) => {setTimeout(resolve.bind(null, hello), 1000)});
 18                     console.log(a: , a);
 19                     let b = await new Promise((resolve, reject) => {setTimeout(resolve.bind(null, world), 2000)});
 20                     console.log(b: , b);
 21                     let c = await new Promise((resolve, reject) => {setTimeout(resolve.bind(null, xyz), 3000)});
 22                     console.log(c: , c);
 23                     return c;
 24                 } catch(error) {
 25                     console.log(error: , error);
 26                 }
 27             }
 28             // 继发调用: 回调嵌套, 抛出最后结果, f() 只用来作为一个流程管理器
 29             // f().then(v => {console.log(‘final-result: ‘+ v);}).catch(e => {console.log(‘final-error-reason: ‘, e);});
 30 
 31 
 32             // 例-2: 并发异步
 33             async function g() {
 34                 try {
 35                     return await Promise.all([
 36                         ajax1(https://api.github.com/users/github, get),
 37                         ajax2(https://api.github.com/users, get),
 38                         ajax3(https://api.github.com, get),
 39                         ajax4(https://api.github.com/users/chosen, get)
 40                     ]);
 41                 } catch(error) {
 42                     console.log(error: , error);
 43                 }
 44             }
 45 
 46             /*
 47             * https://api.github.com/users/github
 48             * https://api.github.com/users
 49             * https://api.github.com
 50             * https://api.github.com/users/chosen
 51             */
 52 
 53             // 并发调用: 全部执行完才抛出最后结果, g() 只用来作为一个流程管理器
 54             g().then(obj => {
 55                 let[github, users, api, chosen] = obj; // 解构
 56                 let [jGithub, jUsers, jApi, jChosen] = [JSON.parse(github), JSON.parse(users), JSON.parse(api), JSON.parse(chosen)]; // 解构转成 js 对象
 57                 // 业务流程
 58                 console.log(---------- all-completed ----------);
 59                 console.log(github >>>>>>, jGithub[login]);
 60                 console.log(users >>>>>>, jUsers[0][login]);
 61                 console.log(api >>>>>>, jApi[current_user_url]);
 62                 console.log(chosen >>>>>>, jChosen[login]);
 63             }).catch(e => {
 64                 console.log(e);
 65             })
 66 
 67 
 68 
 69 
 70 
 71         }
 72 
 73         // --------------- function --------------------
 74 
 75 
 76         // ajax1
 77         function ajax1(url, type) {
 78             return new Promise((resolve, reject) => {
 79                 console.log(ajax1 start~);
 80                 myAjax(url, type, null, function(data) {
 81                     console.log(ajax1-completed!);
 82                     resolve(data);
 83                 }, function(reason) {
 84                     console.log(ajax1-failed!);
 85                     reject(reason);
 86                 })
 87             })
 88         }
 89 
 90         // ajax2
 91         function ajax2(url, type) {
 92             return new Promise((resolve, reject) => {
 93                 console.log(ajax2 start~);
 94                 myAjax(url, type, null, function(data) {
 95                     console.log(ajax2-completed!);
 96                     resolve(data);
 97                 }, function(reason) {
 98                     console.log(ajax2-failed!);
 99                     reject(reason);
100                 })
101             })
102         }
103 
104         // ajax3
105         function ajax3(url, type) {
106             return new Promise((resolve, reject) => {
107                 console.log(ajax3 start~);
108                 myAjax(url, type, null, function(data) {
109                     console.log(ajax3-completed!);
110                     resolve(data);
111                 }, function(reason) {
112                     console.log(ajax3-failed!);
113                     reject(reason);
114                 })
115             })
116         }
117 
118         // ajax4
119         function ajax4(url, type) {
120             return new Promise((resolve, reject) => {
121                 console.log(ajax4 start~);
122                 console.log(---------- cut-off-line ----------);
123                 myAjax(url, type, null, function(data) {
124                     console.log(ajax4-completed!);
125                     resolve(data);
126                 }, function(reason) {
127                     console.log(ajax4-failed!);
128                     reject(reason);
129                 })
130             })
131         }
132         // 以上 4 个函数(ajax1 ~ ajax4)可以进一步封装, 但为了表达清晰, 此处不做处理
133 
134 
135         // 自定义 ajax, 类型仅限于 get 和 post, 回调函数: success/error
136         function myAjax(url, type, params, success, error) {
137             var xhr = null;
138             var args = null;
139             xhr = new XMLHttpRequest();
140             xhr.onreadystatechange = function() {
141                 if (xhr.readyState == 4) {
142                     if ((xhr.status >= 200 && xhr.status < 300) || xhr.status == 304) {
143                         success(xhr.responseText);
144                     } else {
145                         error("Request was unsuccessful: "+ xhr.status);
146                     }
147                 }
148             };
149             xhr.open(type, url, true); // 类型, 连接, 是否异步
150             if (type.toLowerCase() == post) {
151                 // xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); // 默认的表单提交
152                 xhr.setRequestHeader("Content-Type", "application/json; charset=UTF-8"); // JSON.stringify 处理后的json 键值对
153                 args = params;
154             }
155             xhr.send(args);
156         }
157     </script>
158 </body>
159 </html>

 

以上是关于ES6 async await的主要内容,如果未能解决你的问题,请参考以下文章

ES6 async/await语法

ES6 -async ,await

ES6 async await

Swift新async/await并发中利用Task防止指定代码片段执行的数据竞争(Data Race)问题

Swift新async/await并发中利用Task防止指定代码片段执行的数据竞争(Data Race)问题

es6 async await