微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

手写 promise.all

<!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] 举报,一经查实,本站将立刻删除。

相关推荐