温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么构造JavaScript Promise

发布时间:2022-03-03 10:23:14 来源:亿速云 阅读:137 作者:iii 栏目:web开发

这篇“怎么构造JavaScript Promise”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么构造JavaScript Promise”文章吧。

  Promise 是一个 ECMAScript 6 提供的类,目的是更加优雅地书写复杂的异步任务。

  由于 Promise 是 ES6 新增加的,所以一些旧的浏览器并不支持,苹果的 Safari 10 和 Windows 的 Edge 14 版本以上浏览器才开始支持 ES6 特性。

  构造 Promise

  现在我们新建一个 Promise 对象:

  new Promise(function (resolve, reject) {

  // 要做的事情...

  });

  通过新建一个 Promise 对象好像并没有看出它怎样 "更加优雅地书写复杂的异步任务"。我们之前遇到的异步任务都是一次异步,如果需要多次调用异步函数呢?例如,如果我想分三次输出字符串,第一次间隔 1 秒,第二次间隔 4 秒,第三次间隔 3 秒:

  实例

  setTimeout(function () {

  console.log("First");

  setTimeout(function () {

  console.log("Second");

  setTimeout(function () {

  console.log("Third");

  }, 3000);

  }, 4000);

  }, 1000);

  这段程序实现了这个功能,但是它是用 "函数瀑布" 来实现的。可想而知,在一个复杂的程序当中,用 "函数瀑布" 实现的程序无论是维护还是异常处理都是一件特别繁琐的事情,而且会让缩进格式变得非常冗赘。

  现在我们用 Promise 来实现同样的功能:

  实例

  new Promise(function (resolve, reject) {

  setTimeout(function () {

  console.log("First");

  resolve();

  }, 1000);

  }).then(function () {

  return new Promise(function (resolve, reject) {

  setTimeout(function () {

  console.log("Second");

  resolve();

  }, 4000);

  });

  }).then(function () {

  setTimeout(function () {

  console.log("Third");

  }, 3000);

  });

  这段代码较长,所以还不需要完全理解它,我想引起注意的是 Promise 将嵌套格式的代码变成了顺序格式的代码。

以上就是关于“怎么构造JavaScript Promise”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI