JavaScript ES6 Promiss对象
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了JavaScript ES6 Promiss对象,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4270字,纯文字阅读大概需要7分钟。
内容图文
说明
Node.js中,以异步(Async)回调著称,使用了异步,提高了程序的执行效率,但是,代码可读性较差的。
假如有几个异步操作,后一个操作需要前一个操作的执行完毕之后返回的数据才能执行下去,如果使用Node.js,就需要一层层嵌套下去,Promised对象就是针对此问题所提出来的的解决办法。
基本概念
Promise对象状态:
-
pending
初始状态,也称为未定状态,就是初始化Promise时,调用executor执行器函数后的状态。 -
fulfilled
完成状态,意味着异步操作成功。 -
rejected
失败状态,意味着异步操作失败。
状态转换只有这两种pending->fulfilled pending->,可返回的这个Promise对象的状态主要是根据promise1.then()方法返回的值:
状态转化是单向的,不可逆转,已经确定的状态(fulfilled/rejected)无法转回初始状态(pending)
当状态为rejected,该promise无法继续往下执行,需要添加一个catch获得异常信息
回调函数:
-
resolve
当pending
状态转为fulfilled
状态时候回调(操作成功) -
reject
当pending
状态转为rejected
状态时候回调(操作失败)
方法: - then()
- catch()
- all()
- race()
基本使用
new Promise(function(resolve,reject){
//这里面实现异步操作,ajax等..
//获得结果,回调传参
if(/*success*/){
resolve();
}else{
reject();
}
});
//虽然没有去执行setTimeOut函数,但是Promise会自动执行,所以,一般需要将Promise写在一个function里面
new Promise(function(resolve,reject){
setTimeout(function(){
let num = Math.random();
//当随机数小于0.5,当前promise完成了执行
if(num<0.5){
resolve(num);
}else{
reject("错误,num>=0.5");
}
console.log('执行完成');
},2000);
});
let p =new Promise(function(resolve,reject){
setTimeout(function(){
let num = Math.random();
//当随机数小于0.5,当前promise完成了执行
if(num<0.5){
resolve(num);
}else{
reject(num);
}
console.log('执行完成');
},2000);
});
p.then(function(data){
//这里的data是之前resolve中的回调参数
console.log(data);
},function(error){
//这里的error是之前resolve中的回调参数
console.log("错误原因为"+error);
});
进阶使用
then()
Promise then(fun(resolve,reject))
p.then(function(data){
//这里的data是之前resolve中的回调参数
console.log(data);
},function(data){
//这里的data是之前resolve中的回调参数
console.log("错误");
console.log(data);
});
then方法,可以接收回调的参数并进行处理,then方法返回的是一个Promise对象。这里,我们主要关心的是返回的Promise对象的状态。
可返回的这个Promise对象的状态主要是根据promise1.then()方法返回的值:
- 如果then()方法中返回了一个参数值,那么返回的Promise将会变成接收状态。
- 如果then()方法中抛出了一个异常,那么返回的Promise将会变成拒绝状态。
- 如果then()方法调用resolve()方法,那么返回的Promise将会变成接收状态。
- 如果then()方法调用reject()方法,那么返回的Promise将会变成拒绝状态。
- 如果then()方法返回了一个未知状态(pending)的Promise新实例,那么返回的新Promise就是未知状态。
- 如果then()方法没有明确指定的resolve(data)/reject(data)/return data时,那么返回的新Promise就是接收状态,可以一层一层地往下传递。
let p =new Promise(function(resolve,reject){
setTimeout(function(){
let num = Math.random();
//当随机数小于0.5,当前promise完成了执行
if(num<0.5){
resolve(num);
}else{
reject(num);
}
console.log('执行完成');
},2000);
});
p.then(function(data){
//用上次获得的数据执行相关的异步操作
},function(error){
//出现错误,处理错误信息
});
let p =new Promise(function(resolve,reject){
setTimeout(function(){
resolve("hello");
console.log('执行完成');
},2000);
});
p.then(function(data){
console.log(data);
}).then(function(){
setTimeout(function(){
console.log("过了5s,继续执行");
},5000);
});
catch()
catch()方法和then()方法一样,都会返回一个新的Promise对象,它主要用于捕获异步操作时出现的异常。
因此,我们通常省略then()方法的第二个参数,把错误处理控制权转交给其后面的catch()函数。
下面的两段代码块,实现的功能是一样的。
let p =new Promise(function(resolve,reject){
setTimeout(function(){
let num = Math.random();
//当随机数小于0.5,当前promise完成了执行
if(num<0.5){
resolve(num);
}else{
reject(num);
}
console.log('执行完成');
},2000);
});
p.then(function(data){
//用上次获得的数据执行相关的异步操作
},function(error){
//出现错误,处理错误信息
});
let p =new Promise(function(resolve,reject){
setTimeout(function(){
let num = Math.random();
if(num<0.5){
resolve(num);
}else{
reject(num);
}
console.log('执行完成');
},2000);
});
p.then(function(data){
//用上次获得的数据执行相关的异步操作
}).catch(function(error){
//处理错误信息
});
race()
传入参数为可迭代的对象,如数组
两个异步任务同时向同一个url发送请求,谁先得到数据,另外的那个异步任务获得的数据就会被丢弃
//2s后输出“执行完成1”
let p =new Promise(function(resolve){
setTimeout(function(){
resolve("hello");
console.log('执行完成1');
},2000);
});
//1s后输出“执行完成2”
let p1 =new Promise(function(resolve){
setTimeout(function(){
resolve("hello 2");
console.log('执行完成2');
},1000);
});
//两个异步任务同时开始
let mixedPromisesArray = [p,p1];
let p3 = Promise.race(mixedPromisesArray).then(data=>{
//这里的data为hello 2,hello被丢弃
console.log(data);
});
all()
参数也是可迭代的对象,如数组
一般用于几个任务同时并行运行的情况
当某个任务失败,状态就会变为reject
//2s后输出“执行完成1”
let p =new Promise(function(resolve){
setTimeout(function(){
resolve("hello");
console.log('执行完成1');
},2000);
});
//1s后输出“执行完成2”
let p1 =new Promise(function(resolve){
setTimeout(function(){
resolve("hello 2");
console.log('执行完成2');
},1000);
});
//两个异步任务同时开始
let mixedPromisesArray = [p,p1];
let p3 = Promise.all(mixedPromisesArray).then(data=>{
//这里的data数组,存放着之前两个异步回调传的数据
console.log(data);
});
参考
原文:https://www.cnblogs.com/kexing/p/11246670.html
内容总结
以上是互联网集市为您收集整理的JavaScript ES6 Promiss对象全部内容,希望文章能够帮你解决JavaScript ES6 Promiss对象所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。