经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » JavaScript » 查看文章
JavaScript异步编程4——Promise错误处理
来源:cnblogs  作者:charlee44  时间:2021/5/6 17:56:26  对本文有异议

1. 概述

在上一篇文章《JavaScript异步编程3——Promise的链式使用》中,通过Promise的链式使用,避免程序中多次嵌套回调(回调地狱)。根据前面的文章我们可以知道,Promise是基于状态的,成功/失败的状态会分别去处理相应的回调函数。一般而言,失败的状态我们希望能够捕获它,将它像异常(Error)一样处理。

2. 详论

Promise的then()方法有两个参数,一个是成功的回调函数,一个是失败的回调函数。可以将失败的回调函数这个参数省略掉,而使用Promise的catch()方法,捕获失败的异常。例如,我们把上一篇文章中的例子改进一下:

  1. $(function () {
  2. function get(url) {
  3. return new Promise(function (resolve, reject) {
  4. var req = new XMLHttpRequest();
  5. req.open('GET', url);
  6. req.onload = function () {
  7. //即使是404也会进入这个相应函数,所以需要检测状态
  8. if (req.status == 200) {
  9. //完成许诺,返回响应文本
  10. resolve(req.response);
  11. } else {
  12. //完成未完成,返回错误
  13. reject(Error(req.statusText));
  14. }
  15. };
  16. // 发生错误时的相应函数
  17. req.onerror = function () {
  18. reject(Error("Network Error"));
  19. };
  20. // 发送请求
  21. req.send();
  22. });
  23. }
  24. function getImg(uri){
  25. return new Promise(function(resolve, reject){
  26. var img = new Image();
  27. img.onload = function () {
  28. resolve(img);
  29. };
  30. img.onerror = function () {
  31. reject(Error("Load Image Error!"));
  32. }
  33. img.src = uri;
  34. });
  35. }
  36. var addressUri = "./1.json";
  37. get(addressUri).then(function (response) {
  38. var imgJson = JSON.parse(response);
  39. return getImg(imgJson[0]);
  40. }).catch(function (error) {
  41. console.error("Failed!", error);
  42. }).then(function(img){
  43. $(img).appendTo($('#container'));
  44. }).catch(function(error){
  45. console.error("Failed!", error);
  46. });
  47. });

改进前与改进后的程序处理流程很相似,但是还是有细微的差别。前者通过Promise的then()处理异常,只会运行功能的回调函数和失败的回调函数其中的一个;后者通过catch()处理异常,则更加像JavaScript的try/catch,在try{}中发生的错误会立即转到catch{}块。这样的话,就很容易实现类似于try/catch异常操作的的非阻塞异步版本:

  1. $(function () {
  2. function get(url) {
  3. return new Promise(function (resolve, reject) {
  4. var req = new XMLHttpRequest();
  5. req.open('GET', url);
  6. req.onload = function () {
  7. //即使是404也会进入这个相应函数,所以需要检测状态
  8. if (req.status == 200) {
  9. //完成许诺,返回响应文本
  10. resolve(req.response);
  11. } else {
  12. //完成未完成,返回错误
  13. reject(Error(req.statusText));
  14. }
  15. };
  16. // 发生错误时的相应函数
  17. req.onerror = function () {
  18. reject(Error("Network Error"));
  19. };
  20. // 发送请求
  21. req.send();
  22. });
  23. }
  24. function getImg(uri){
  25. return new Promise(function(resolve, reject){
  26. var img = new Image();
  27. img.onload = function () {
  28. resolve(img);
  29. };
  30. img.onerror = function () {
  31. reject(Error("Load Image Error!"));
  32. }
  33. img.src = uri;
  34. });
  35. }
  36. var addressUri = "./1.json";
  37. get(addressUri).then(function (response) {
  38. var imgJson = JSON.parse(response);
  39. return getImg(imgJson[0]);
  40. }).then(function(img){
  41. $(img).appendTo($('#container'));
  42. }).catch(function(error){
  43. console.error("Failed!", error);
  44. }).then(function(){
  45. alert("图片加载完成!");
  46. });
  47. });

在上面这个改进的例子中,第一个then()和第二个then()中如果存在错误,就会将异常转到catch()中,而第三个then(),则是程序无论如何都会往下继续运行的。

3. 参考

  1. JavaScript Promises: An introduction

原文链接:http://www.cnblogs.com/charlee44/p/14729077.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号