异步解决方案良药Promise
栏目: JavaScript · 发布时间: 5年前
内容简介:目前比较流行的异步解决方案,本质上是一个构造函数promise有三种状态,初始的状态都是pedding,包括成功的状态失败的状态还有等待的状态我们来通过一个例子来说明一下异步调用的问题
异步解决方案良药Promise
promise
目前比较流行的异步解决方案,本质上是一个构造函数
1、状态
promise有三种状态,初始的状态都是pedding,包括成功的状态失败的状态还有等待的状态
- promise.all()所有的promise对象成功才会触发成功的状态,否则失败状态
- promise.race()任意一个子promise的状态触发后
2、出现的原因
我们来通过一个例子来说明一下异步调用的问题
let url1 = 'http://xxx.xxx.1'; $.ajax({ url:url1, error:function (error) {}, success:function (data1) { console.log(data1); } });
那当我们发出多个请求的时候就只能以嵌套的方式来解决
let url1 = 'http://xxx.xxx.1'; let url2 = 'http://xxx.xxx.2'; let url3 = 'http://xxx.xxx.3'; $.ajax({ url:url1, error:function (error) {}, success:function (data1) { console.log(data1); $.ajax({ url:url2, data:data1, error:function (error) {}, success:function (data2) { console.log(data2); $.ajax({ url:url3, data, error:function (error) {}, success:function (data3) { console.log(data3); } }); } }); } });
3、主要的问题
- 代码臃肿。
- 可读性差。
- 耦合度过高,可维护性差。
- 代码复用性差。
- 容易滋生 bug。
- 只能在回调里处理异常。
4 、Promise 的使用
构造函数
Promise 是一个构造函数,使用 new 操作符返回一个 promise 对象
构造函数接收一个 excutor 函数作为参数
excutor 函数有两个函数类型的参数 resolve 和 reject
以上所述就是小编给大家介绍的《异步解决方案良药Promise》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 中了源码的毒,给你一副良药
- SpringBoot | :异步开发之异步调用
- 改进异步封装:处理带返回值的异步调用
- 异步发展流程 —— Generators + co 让异步更优雅
- 文件系统与异步操作——异步IO那些破事
- js异步从入门到放弃(四)- Generator 封装异步任务
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
JavaScript语言精粹
Douglas Crockford / 赵泽欣、鄢学鹍 / 电子工业出版社 / 2009-4 / 35.00元
本书通过对JavaScript语言的分析,甄别出好的和坏的特性,从而提取出相对这门语言的整体而言具有更好的可靠性、可读性和可维护性的JavaScript的子集,以便你能用它创建真正可扩展的和高效的代码。 雅虎资深JavaScript架构师Douglas Crockford倾力之作。 向读者介绍如何运用JavaScript创建真正可扩展的和高效的代码。一起来看看 《JavaScript语言精粹》 这本书的介绍吧!