浅谈Promise


1.Promise的概述

promise 是 es6 提出的一个异步解决方案,比传统回调事件的写法更加合理更加强大,主要还是优雅

promise 有 pending(等待中),fulfilled(已成功),rejected(已失败),只有异步操作的结果才能够将状态改变,且只会有 pending->fulfilled 或者 pending->rejected,只要状态改变,会一直保持这个结果


2. Promise的状态

resolve : 将 Promise的状态设置为 fullfilled (已成功)
reject : 将 Promise 的状态设置为 rejected (已失败)
Promise 的状态 一旦改变, 不可更改。

我们可以以 承诺买房 作为例子进行演示:

	let promise = new Promise((resolve, reject) => {
		//未完成承诺
		reject("您失信了")
		//完成承诺
		resolve("已经买过房子了")
	})
	console.log(promise)

3. Promise对象的创建方式

创建Promise对象有三种方式

  1. new Promise((resolve, reject) => {} ) // promise 的状态由回调函数来进行切换
  2. Promise.resolve(data) // 快速构建一个 fulfilled 状态的 promise
  3. Promise.reject(data) // 快速构建一个 rejected 状态的 promise

4. Promise#then 方法的特点

then 支持两个回调函数

  1. 第一个回调函数,代表 Promise 状态为 fulfilled 执行的回调。
  2. 第二个回调函数, 代表 promise 状态为 rejected 执行的回调。

下面是代码演示:

	p.then(res=> {
		console.log(res)	
	}, err=> {
		console.log(err)
	})

在resolve和reject都有的情况下,reject是不执行的。

then 会重新返回promise,两个函数,一个返回rresolve 一个返回reject。

	var p1= new Promise(function (resolve, reject) {
	resolve({
		data: [1, 2, 3, 4],
		resposneCode: "00001",
		resposneRemark: "成功"
	})

	reject({
		resposneCode: "00000",
		resposneRemark: "失败,遇到网络问题",
		data: [2]
	})

	}).then(function ({ data }) { return { data } }, function ({ data }) { return { data } });

	p1.then(function (data) { console.log(data) }, function ({ data }) { return { data } });

5. Promise 链式调用

then :
1. 处理 承诺 已完成的 业务
2. 更改 返回的 新的 promise 对象的状态
3. then 方法会返回一个 新的 promise 对象
4. then 方法的回调函数如果能被执行, 新的 promise 对象 状态由 回调函数 确定

  1. 如果回调函数产生异常, 则返回 rejected 状态的 promise
  2. 如果回调函数 没有 return ,则 返回 fulfilled 状态,并将 undefined 作为参数传给新的promise
  3. 如果回调函数 return 普通数据、则将 普通数据 作为 resolve 的 参数传给新的 promise
  4. 如果回调函数 return 一个 promise 对象,则then 返回的新的promise 对象状态和 return
    的promise对象状态完全一致

5.then 方法的回调函数如果不能执行,新的 promise 对象 和 调用 then 方法的 promise状态 完全一致

 	let th = p.then( res => {
		console.log(res)
		// 回调函数 return 的结果,会默认作为 fulfilled状态的 resolve() 函数的参数
		throw "error2" ;
	})
		console.log(th, "outter")
		setTimeout(function() {
			console.log(th,  "timeout")
			console.log(th === p)
		} , 0)	

6.Promise.resolve 传入的参数类型

Promise.resolve(arg) 快速的创建一个状态为 fulfilled的 promise
arg 参数的类型满足以下条件:

  1. arg是一个普通数据,会构建一个 fulfilled状态的 promise,并将 arg 的值 作为 resolve的参数
  2. arg 是 undefined, 会将 undefined 作为 resolve的参数,并返回 fulfilled状态的
    promise
  3. arg 是一个 thenable(某个对象中有 then 方法) 对象, 那么 会直接执行 then 方法,
    返回的promise对象状态由 then函数来确定
  4. arg 是一个promise 对象, 那么会返回一个 和 arg promise对象状态完全一致的 promise
    以下是代码演示:

普通数据:

Promise.resolve(arg) //快速的创建一个状态为 fulfilled的 promise 

undefined:

Promise.resolve().then(res=> console.log(res))

thenable对象:

	let obj = {
		name: "zhangsan",
		then() {
		//console.log(this.name, "在说话")
		throw Error("error")
		}
	}		
	let p = Promise.resolve(obj)
	setTimeout( function(){
		console.log(p)
	 }, 0)

promise 对象:

	let p = new Promise((resolve, reject)=> {
		reject("ok")
	})
	let p2 = Promise.resolve(p)
	setTimeout(function(){
		console.log(p2)
	})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值