JavaScript 中的 Promise 链是什么?

在本教程中,我们将讨论 JavaScript 中的 Promise 链。在转向 Promise 链之前,我们先来谈谈什么是 Promise

因此,我们知道 JavaScript 是单线程的,这意味着不允许两个函数同时运行,因为我们只有一个调用堆栈,如下所示,它有一个要执行的函数

当一个函数完成执行时,另一个函数开始执行,因此为了实现两个或多个函数同时运行,我们在 JavaScript 示例中使用异步编程 – setTimeout 函数,它接受一个回调函数和指定的时间,之后它将执行执行该函数。

setTimeout(function cT(){
   console.log("I am here after 5 seconds")
}, 5000);

因此,我们对异步操作使用 Promise,它给出异步操作的结果及其完成或失败。

就像在现实生活中一样,我们以与做出承诺相同的方式承诺完成任何工作,并且它存在于三种状态之一。

  • 待处理 – 这代表初始状态,表示它既未完成也未拒绝。
  • Fulfilled – 这表示我们分配的操作已成功完成。
  • 拒绝 – 此状态表示操作无法执行,它被拒绝。

异步方法返回一个值,但它不返回最终值,而是返回一个将来为该函数提供值的承诺。

我们在 Promise 语句之后使用 then() 方法执行 Promise,如果由于某些错误而被拒绝,则将使用 catch 块进行处理。

如何在 JavaScript 中声明 Promise?

let promise = new Promise(function (resolve, reject) {
   return resolve("Hello I am resolved");
});

这里的promise内部有一个函数,称为回调函数,它有一个参数作为两个方法resolve()reject(),正如我们已经知道的那样从上面关于两者的解释来看。

因此,这里的resolve确保我们给出的函数的成功完成,而reject将确保它对给定的可执行回调函数不成功完成的责任。

示例 1

让我们看看使用 Set 查找字符串中唯一字符的程序。

<!DOCTYPE html>
<html>
<head>
   <title>Promise chaining in JavaScript</title>
</head>
<body>
   <h3> Execute a Promise we receive</h3>
   <p id ="result"></p>
   <script>
      let promise = new Promise(function (resolve, reject) {
         return resolve("Hello I am resolved");
      });
      promise.then(function(value) {
         console.log(value);
         document.getElementById("result").innerHTML += value;
      })
   </script>
</body>
</html>

在上面里面。 then() 方法会传递一个回调函数,value 变量负责打印出来自resolve() 方法的结果。

什么是承诺链?

Promise 链基本上是多个异步函数调用,并以同步方式依次执行它们。 then() 方法。

示例 2

让我们通过一个例子来详细理解。

<!DOCTYPE html>
<html>
<head>
   <title>Promise chaining in JavaScript </title>
</head>
<body>
   <h3> Promise Chaining</h3>
   <p id ="result"></p>
   <script>
      let promise = new Promise(function (resolve, reject) {
         return resolve(10);
      });
      promise.then(function(firstPromise_val) {
         alert(firstPromise_val)
         document.getElementById("result").innerHTML += "First Promise val: "+firstPromise_val+"<br>";
         return firstPromise_val+10;
      }).
      then(function(secondPromise_val){
         alert(secondPromise_val)
         document.getElementById("result").innerHTML +="Second Promise val: "+ secondPromise_val+"<br>";
         return secondPromise_val+10;
      }).
      then(function(thirdpromise_val){
         alert(thirdpromise_val)
         document.getElementById("result").innerHTML +="Third Promise val: "+thirdpromise_val+"<br>";
         return thirdpromise_val+10;
      })
   </script>
</body>
</html>  

让我们了解承诺链是如何工作的。

  • 第一个最初的承诺得到了兑现。
  • 然后 .then() 方法调用它创建了一个新的 Promise 并得到了解析。
  • 再次调用 .then() 方法,它创建了一个新的 Promise,然后它也得到了解析。
  • 同样,它正在工作,我们也可以添加另一个承诺处理程序。

所以,基本上 .then() 方法返回一个新的 Promise,并使用 .then() 调用 next 等等。

示例 3

<!DOCTYPE html>
<html>
<head>
   <title>Promise chaining in javascript</title>
</head>
<body>
   <h3> Promise Chaining</h3>
   <p id ="result"></p>
   <script>
      let promise = new Promise(function (resolve, reject) {
         return resolve("My");
      }).
      then(function(firstPromise_val) {
         alert(firstPromise_val)
         return firstPromise_val+" Name";
      }).
      then(function(secondPromise_val){
         alert(secondPromise_val)
         return secondPromise_val+" is";
      }).
      then(function(thirdpromise_val){
         alert(thirdpromise_val)
         return thirdpromise_val+" Kalyan";
      }).
      then(function(thirdpromise_val){
         alert(thirdpromise_val)
         document.getElementById("result").innerHTML = thirdpromise_val
      })
   </script>
</body>
</html>

因此,我们看到了有关其工作原理的从基础到承诺链的深入概念。

以上就是JavaScript 中的 Promise 链是什么?的详细内容,更多请关注双恒网络其它相关文章!

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
8. 精力有限,不少源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别
9.本站默认解压密码为:www.sudo1.com
本站提供的一切软件、教程和内容信息仅限用于学习和研究目的。
不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。
本站信息来自网络收集整理,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑或手机中彻底删除上述内容。
如果您喜欢该程序和内容,请支持正版,购买注册,得到更好的正版服务。
我们非常重视版权问题,如有侵权请邮件与我们联系处理。敬请谅解!

云资源网 » JavaScript 中的 Promise 链是什么?

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
提示下载完但解压或打开不了?
最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。 若排除这种情况,可在对应资源底部留言,或 联络我们.。
你们有qq群吗怎么加入?
当然有的,如果你是帝国cms、易优cms、和pbootcms系统的爱好者你可以加入我们的QQ千人交流群https://www.sudo1.com/page-qun.html。
  • 会员数(个)
  • 12334资源数(个)
  •        
  • 资源(G)
  •        
  • 今日下载
  • 1427稳定运行(天)

提供最优质的资源集合

立即查看 了解详情