<!DOCTYPE html> <html lang="en"> <head> <Meta charset="UTF-8" /> <Meta http-equiv="X-UA-Compatible" content="IE=edge" /> <Meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>promise.all第二遍</title> </head> <body> <script> function promiseAll(_promises) { return new Promise((resolve, reject) => { const promises = [..._promises]; const arr = []; let count = 1; for (let i = 0; i < promises.length; i++) { Promise.resolve(promises[i]).then( data => { arr[i] = data; if (++count === promises.length) { resolve(arr); } }, err => { reject(err); } ); } }); } function promiseAll1(_promises) { return new Promise((resolve, reject) => { const promises = [..._promises]; const arr = []; let count = 1; for (let i = 0; i < promises.length; i++) { Promise.resolve(promises[i]).then( data => { arr[i] = data; if (++count === promises.length) { resolve(arr); } }, err => { reject(err); } ); } }); } function promiseAll2(_promises) { return new Promise((resolve, reject) => { const promises = [..._promises]; let count = 1; const arr = []; for (let i = 0; i < promises.length; i++) { Promise.resolve(promises[i]).then( data => { arr[i] = data; if (++count === promises.length) { resolve(arr); } }, err => { reject(err); } ); } }); } let a = `回调函数延迟绑定;错误冒泡,返回值穿透`; </script> </body> </html>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。