Promise 承诺

一:promise概念

  在js中,promise是一个对象,是专门用来处理异步操作 / 回调地狱的,那么什么是回调地狱?设计到同步和异步任务的知识,在js中,因为js是单线程,无法多并发处理任务,当在js中运行代码时,首先会优先执行同步代码,而异步代码则必须等到同步代码全部执行完才会被执行,那么每个异步代码的加载都需要时间,有快有慢,当我们需求让异步按照我们自己的开发想法来运行,显然需要进行嵌套才能让异步任务有序的按照我们自己的想法执行,就是在这一不断嵌套的过程中,就会形成回调地狱,一不便于管理,代码耦合严重,二代码非常难看,那么promise的出现就解决了这回调地狱的带来的不好的体验。

二:promise的特点  

  1:在promise中,总共有三种状态,分别是准备中(pending),成功时(resolved)和失败时(rejected)

  2:一但创建,状态立即时pending,只有异步返回的结构可以改变其状态,且能能由pending—>resolved 或者 pending -->rejected,没用其他情况

三:promise的语法和方法

  (1):使用promise时,需要使用 new 出来

 var pms = new Promise(function(resolve,reject){
var i = 3;
if(i>3){
// resolve 表示正确完成时执行的函数
resolve();
}else{
// reject 表示失败时执行的函数
reject();
}
})
// 调用 promise 下的两个回调函数 - then 方法
pms.then(function(){
// 当正确时执行
console.log('执行resolve回调函数');
},function(){
// 当失败时执行
console.log('执行reject回调函数');
})

  Promise对象的回调函数下有两个参数,都是回调函数:第一个参数resolved,第二个参数rejected,分别对应成功状态和失败状态,使用then方法来获取返回的结果和状态。

  Promise的then 方法:promise对象中用来执行回调函数的方法,then方法接受两个参数,第一个是成功的resolved的回调,另一个是失败rejected的回调

            且第二个失败的回调参数可选。并且then方法里也可以返回promise对象。

  (2):promise的状态只被执行一次

 // promise 状态只能被执行一次
var pms = new Promise(function(resolve,reject){
// 1:在 promise 中 resolve和reject,只能被调用一次,不能同时调用
// 2:当执行resolve或者reject时,这个Promise当中状态就会被修改
resolve(4) // 只执行第一个,后面的不执行
reject(3)
resolve(2)
reject(1)
})
// 调用 promise - then方法
// catch 方法:是promise中执行 promise发生错误时的方法
pms.then(function(num){
console.log(num) //
}).catch(function(num){
console.log(num)
})

  使用promise,他的状态要么从pending改变成resolve,要么就是从pending改变成reject,当在promise中调用多次promise对象的回调,只会执行一次。

  catch 方法是promise中执行 promise发生错误时的方法

  (3):promise的resolve和reject方法

 // Promise.resolve() 方法:直接执行Promise的resolve方法,并且传入参数
// 返回一个Promise对象,状态为resolve
// pmsRes 的状态为 resolve
var pmsRes = Promise.resolve(3).then(function(num){
console.log(num); //
}) // Promise.reject() 方法:直接执行Promise的reject方法,并且传入参数
// 返回一个Promise对象,状态为rejected
// pmsRes 的状态为 reject
var pmsRej = Promise.reject(1).then(function(num){
console.log(num); // Uncaught (in promise) 1
})

   (4):promise.all()的方法 - all中的参数是一个数组,数组中放置的时promise对象,只有当数组中所有的都执行成resolve状态,才会执行all方法,注意,一定是所有,有一个是为失败,all方法不会执行,相当于运算符且 &&

 function loadImage(src){
var pms = new Promise(function(resolve,reject){
var img = new Image()
// 给 img 添加 load事件 和 error事件,由promies 回调函数返回结果
img.onload = function(){
resolve(img);
}
img.onerror = function(){
// 当错误时,执行reject
reject(src);
}
// 给img 添加地址 - 在这里为同步代码
img.src = src;
})
// 返回这个 promies 对象
return pms;
}
var arr = [];
for(var i = 0;i < 5;i++){
var res = loadImage('./images/'+i+'.jpg');
arr.push(res);
}
// 当arr数组中所有的都完成了,才会执行all方法
Promise.all(arr).then(function(list){
list.forEach(itme=> {
// 在这里只有图片都完成,才会打印所有图片的宽度
console.log(itme.width);
});
})

图片格式:

  (5): 连缀式写法,处理回调地狱

 

 function loadImage(src){

     var pms = new Promise(function(resolve,reject){
// 创建图片
var img = new Image()
// 给 img 添加 load事件 和 error事件,由promies 回调函数返回结果
img.onload = function(){
// 当正确时,执行resolve
resolve(img);
}
img.onerror = function(){
// 当错误时,执行reject
reject(src);
}
// 给img 添加地址 - 在这里为同步代码
img.src = src;
})
// 返回这个 promies 对象
return pms;
}
// promies 连缀式写法:结合loadImage函数
// then调用 return 返回下一次的结果
loadImage('./img/5-.jpg').then(function(img){
console.log(img.width,img.src)
return loadImage('./img/6-.jpg');
}).then(function(img){
console.log(img.width,img.src)
return loadImage('./img/7-.jpg');
}).then(function(img){
console.log(img.width,img.src)
return loadImage('./img/8-.jpg');
}).then(function(img){
console.log(img.width,img.src)
return loadImage('./img/9-.jpg');
}).then(function(img){
console.log(img.width,img.src);
})

  如上,通过不断 return 返回promise对象,那么图片的加载就会按照我们自己的想法顺序加载。且比较美观,当图片较多,可以通过循环的方式来返回promise对象,就不需要一直连缀下去了。

  

最新文章

  1. 安装zookeeper
  2. java语法基本知识3--this
  3. ACM3 求最值
  4. display:none与visibility: hidden的区别
  5. js作用域和词法分析
  6. InputStream和Reader区别
  7. 1503 - A PRIMARY KEY must include all columns in the table&#39;s partitioning function
  8. Json-lib - java.util.Date 转换问题
  9. git workflow 原文 以及缺点
  10. NSCondition用法
  11. 你真的会 snapshot 吗? - 每天5分钟玩转 OpenStack(163)
  12. 打印zigzag矩阵
  13. 用css属性画出一棵圣诞树
  14. JAVA接口基础知识总结
  15. Python SMTP邮件发送
  16. 【阿里云服务器】外网无法访问tomcat下部署的项目
  17. java中的数据加密1 消息摘要
  18. oracle 62进制序列号
  19. mongodb最大连接数、最大连接数修改
  20. centos6.8升级python3.5.2

热门文章

  1. MySQL索引实践
  2. 你都这么拼了,面试官TM怎么还是无动于衷?
  3. Python模拟用户登录场景
  4. vuex登录验证及保持登录状态
  5. numpy中array数组对象的储存方式(n,1)和(n,)的区别
  6. 深度学习中环境配置的一些经验总结(conda 常用命令)
  7. 如何在VMware虚拟机中安装CentOS6.7系统(上篇)
  8. 初步了解Windows7下部署Sonar
  9. Beta冲刺&lt;10/10&gt;
  10. JavaWeb的登陆与注销功能