什么是Promise

Promise是异步编程的一种解决方案,它有三种状态,分别是pending-进行中resolved-已完成rejected-已失败

当Promise的状态又pending转变为resolved或rejected时,会执行相应的方法,并且状态一旦改变,就无法再次改变状态,这也是它名字promise-承诺的由来

直接上案例了,在案例中理解:

最简单的promise

new Promise(resolve =>{
setTimeout(()=>{
resolve('hello')
},2000);
}).then(value=>{
console.log(value + 'world');
})
 
分两次,顺序执行
console.log('start');
new Promise(resolve => {
setTimeout(() => {
resolve('hello');
}, 2000);
})
.then(value => {
console.log(value);
return new Promise(resolve => {
setTimeout(() => {
resolve('world');
}, 2000)
});
})
.then(value => {
console.log(value + ' world');
}); // 结果
// start
// hello (2s)
// worldworld (4s)
 
假如一个promise已经完成,再.then()会怎样
console.log('start');

let promise = new Promise(resolve=>{
setTimeout(()=>{
console.log('this promise fullfilled');
resolve('hello,world')
},2000);
}); setTimeout(()=>{
promise.then(value=>{
console.log(value);
})
},4000) // 结果
// start
// this promise fullfilled (2s)
// hello,world (4s) //在任何地方生成一个promise后,可以存为一个变量,不管该promise有完成,都会依次根据队列执行
假如在 .then() 的函数里面不返回新的 Promise, 会怎样?
console.log('start');
new Promise(resolve => {
setTimeout(() => {
resolve('hello')
}, 2000);
})
.then(value => {
console.log(value);
(function () {
return new Promise(resolve => {
setTimeout(() => {
console.log('第二个promise');
resolve('Merry')
}, 2000);
})
}());
return false;
})
.then(value => {
console.log(value + 'world');
}) // 结果
// start
// hello (2s)
// falseworld (2s)
// 第二个promise (4s) //.then() 的函数里面不返回新的 Promise,会默认执行下一个环节,即使你直接返回了false,也会执行 // 备注
// 匿名函数,(function(){})();立即执行,主要利用函数内的变量作用域,避免产生全局变量,影响整体页面环境,增加代码的兼容性。
.then()接受两个函数作为参数,分别代表fulfilled和rejected
.then()返回一个新的promise实例,所以它可以链式调用
状态相应函数可以返回新的promise或其他值,如果返回新的Promise,那么下一级.then()会在新的Promise状态改变后执行
!!如果返回其他任何值,则会立即执行下一级.then()
.then()里面有.then()的情况
会等里面的.then()执行完,再执行外面的。最好不要这样写,依次展开效果一样
new Promise(resolve => {
console.log('start');
setTimeout(() => {
console.log('1');
resolve('1');
}, 1000)
})
.then(value => {
return new Promise(resolve => {
setTimeout(() => {
console.log('1-1');
resolve('1-1');
}, 1000)
})
.then(value => {
console.log('1-2');
return value;
})
.then(value => {
console.log('1-3');
return value;
})
})
.then(value => {
console.log('2');
}) /*
结果:
start
1
1-1
1-2
1-3
2
*/
错误处理两种做法:
Promise会自动捕获内部异常,并交给rejected响应函数处理
1.reject('错误信息').then(null,message=>{})
2.throw new Error('错误信息').catch(message=>{})
推荐时候用第二种,更加清晰,并且可以捕获前面的错误
console.log('go');
new Promise((resolve,reject)=>{
setTimeout(()=>{
reject('bye')
// throw new Error('bye');
},1000)
})
.then(value=>{
console.log(value+'world');
})
.catch(error=>{
console.log('error:',error);
}) // go
// error: bye
.catch() + .then()连用
 .catch()也会返回一个promise实例
 建议在所有队列后面都加上.catch()
console.log('go');
new Promise(resolve=>{
setTimeout(() => {
resolve('');
}, 1000);
})
.then(()=>{
console.log('start')
throw new Error('test error');
})
.catch((err)=>{
console.log('I catch:'+ err); // 下面一行代码的注释讲引发不同的走向
throw new Error('another error');
})
.then(()=>{
console.log('arrive here');
})
.then(()=>{
console.log('and here');
})
.catch((err)=>{
console.log('I catch:'+ err);
}) /*
结果一:
go
start
I catch:Error: test error
arrive here
and here
结果二:
go
start
I catch:Error: test error
I catch:Error: another error */
Promise.all([p1,p2,p3,...]); 批量同时执行多个promise实例,包装成一个新的promise实例,返回的是所有promise结果组成的数组
console.log('go');
Promise.all([1,2,3])
.then(all=>{
console.log('1:',all);
return Promise.all([function(){
console.log('ooxx');
},'xxoo',false])
})
.then(all =>{
console.log('2:',all);
let p1 = new Promise(resolve=>{
setTimeout(() => {
resolve('I`m P1');
}, 1000);
});
let p2 = new Promise(resolve=>{
setTimeout(() => {
resolve('I`m P2');
}, 3000);
});
return Promise.all([p1,p2]);
})
.then(all =>{
console.log('3:',all);
let p1 = new Promise(resolve=>{
setTimeout(() => {
resolve('I`m P1');
}, 1000);
});
let p2 = new Promise((resolve,reject)=>{
setTimeout(() => {
reject('I`m P2');
}, 1000);
});
let p3 = new Promise((resolve,reject)=>{
setTimeout(() => {
reject('I`m P3');
}, 1500);
});
return Promise.all([p1,p2,p3]);
})
.then(all=>{
console.log('all:',all);
})
.catch(err=>{
console.log('catch',err); }) /*
结果:
go
1: [ 1, 2, 3 ]
2: [ [Function], 'xxoo', false ]
3: [ 'I`m P1', 'I`m P2' ]
catch I`m P2
*/

promise学习总结的更多相关文章

  1. Javascript - Promise学习笔记

    最近工作轻松了点,想起了以前总是看到的一个单词promise,于是耐心下来学习了一下.   一:Promise是什么?为什么会有这个东西? 首先说明,Promise是为了解决javascript异步编 ...

  2. Promise 学习笔记 - 时间支配者

    本文同步自我的个人博客:http://www.52cik.com/2015/11/08/promise.html JavaScript 的 promises 事实标准称为 Promises/A+.ES ...

  3. Javascript Promise 学习 (中)

    时隔多日,对promise有了多一点点的了解. 最近用angularjs 做开发,所以研究了一下它的 $q 功能不算很强大,算是简化版的 Q.js 参考了一下源码,不过我的等级还差很多... 作为学习 ...

  4. Javascript Promise 学习(上)

    Promise 就是处理异步的一个规范方法 a();b();alert("a");如果a() 里面有一个ajax 或者settimeout 那么alert("a" ...

  5. JavaScript之Promise学习笔记

    一直想知道Promise到底是怎么实现的,网上一搜几十篇文章,看的一脸蒙蔽.最后算是找到几个讲的真心很详细明了的.看了一份源码看了很久很久……最后找大佬问了几处看不懂的地方,大佬只看了十几分钟就看懂了 ...

  6. Promise学习探究

    学习熟知吧,原理还是继续吧 例子1: var isGeted; function getRet(){ return new Promise(function(resolve, reject) { // ...

  7. Promise 学习心得

    当了这么久码农到今天没事才开始去深究 Promise 这个对象 什么是 Promise, Promise 有什么用? 在写代码的时候多多少少都有遇见过地狱式的回调 代码看起来没问题就是有点乱,Prom ...

  8. js的Promise学习笔记(1)

    1: 何为Promise Promise是抽象异步处理对象以及对其对象进行各种操作的组件,是基于并列/并行处理设计的一种编程语言. 说到基于JavaScript的异步处理,大多数都会想到利用回调函数. ...

  9. Promise学习

    转自:http://www.cnblogs.com/lvdabao/p/es6-promise-1.html 去年6月份, ES2015正式发布(也就是ES6,ES6是它的乳名),其中Promise被 ...

  10. Promise 学习笔记

    所谓Promise,简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果.从语法上说,Promise是一个对象,从它可以获取异步操作的消息.Promise提供统一的API, ...

随机推荐

  1. tarjan代码

    还有五天就是NOIP2018了……本蒟蒻还要复习期中考试,因此实在没有时间写博客了(各种找借口).这里就放一下代码 //Tarjan缩点 //题目描述:给一个有向图.每个点有一个权值,求权值和最大的路 ...

  2. 插入排序(Python实现)

    目录 1. for版本--插入排序 2. while版本--插入排序 3. 测试用例 4. 算法时间复杂度分析 1. for版本--插入排序 def insert_sort_for(a_list): ...

  3. python tuple的函数

    1. len(tuple) 计算元组元素个数 >>> tuple1 = ('Google', 'Runoob', 'Taobao') >>> len(tuple1) ...

  4. Nginx 多域名配置

    nginx绑定多个域名可又把多个域名规则写一个配置文件里,也可又分别建立多个域名配置文件,我一般为了管理方便,每个域名建一个文件,有些同类域名也可又写在一个总的配置文件里.一.每个域名一个文件的写法  ...

  5. 创建servlet程序知识点详解---servlet-day12

    自定义标签 (1)编程步骤 step1 jsp标签分为复杂标签技术(old),简单标签(new) 注(了解) jsp标签技术分为复杂标签技术(old),简单标签技术(new) step2 ###MVC ...

  6. Python Redis 常用操作

    delete(*names) # 根据删除redis中的任意数据类型 exists(name) # 检测redis的name是否存在 keys(pattern='*') # 根据模型获取redis的n ...

  7. Dijkstra双栈算术表达式求值

    在看algs4的时候偶然发现了这个算法,又回顾了一遍当时数据结构课程里讲过的知识,当时很不在意.迟早是要还的,哎 用python实现了,比较麻烦的是我现在没有解决bash传参的问题,''(" ...

  8. Reading Lines from File in C++

    Reading Lines from File in C++ In C++, istringstream has been used to read lines from a file. code: ...

  9. 5分钟学会vue中的路由守卫(导航守卫)

    在项目开发中每一次路由的切换或者页面的刷新都需要判断用户是否已经登录,前端可以判断,后端也会进行判断的,我们前端最好也进行判断. vue-router提供了导航钩子:全局前置导航钩子 beforeEa ...

  10. linux --- 8. mysql数据库,redis 数据库

    一. mysql 数据库 1.安装方式 ①yum安装 ②源代码编译安装 ③rpm包安装 yum安装的前提条件,是准备好yum源,可以选择163源,清华源,阿里云源,等等等 .安装mariadb的yum ...