2021-06-02

Promise 的简单介绍

  1. Promise的概述

    promise 是 es6 提出的一个比传统回调事件的写法更加合理更加强大
    
  2. Promise的状态

    resolve :  将 Promise的状态设置为 fullfilled (已成功)
    reject:  将 Promise 的状态设置为 rejected (已失败)
    Promise 的状态 一旦改变, 不可更改
    
  3. Promise对象的创建方式

    a)	new Promise((resolve, reject) => {} ) : promise 的状态由回调函数来进行切换
    b)	Promise.resolve(data) : 快速构建一个 fulfilled 状态的 promise  
    c)	 Promise.reject(data) : 快速构建一个 rejected 状态的 promise\
    
	let p = Promise.resolve("ok") 
	//不同的方法
	// let p = new Promise((resolve, reject) => {
	// 	resolve("ok")
	// })
	
		p.then(res => {
			return Promise.reject("error")
		}).catch(error => {
			console.error(error)
		})
  1. Promise#then 方法的特点

     then 支持两个回调函数
     	第一个回调函数,代表 Promise 状态为 fulfilled 执行的回调
     	第二个回调函数, 代表 promise 状态为 rejected 执行的回调
    
  2. Promise 链式调用

      then : 
    	1. 处理 承诺 已完成的 业务
    	2. 更改 返回的 新的 promise 对象的状态
    	  then 方法会返回一个 新的 promise 对象
    	   a) then 方法的回调函数如果能被执行, 新的 promise 对象 状态由 回调函数 确定
    		 1)  如果回调函数产生异常, 则返回 rejected 状态的 promise 
    		 2) 如果回调函数 没有 return ,则 返回 fulfilled 状态,并将 undefined 作为参数传给新的promise
    		 3) 如果回调函数 return 普通数据、则将 普通数据 作为 resolve 的 参数传给新的 promise
    		 4) 如果回调函数 return 一个 promise 对象,则then 返回的新的promise 对象状态和 return
    		    的promise对象状态完全一致
    	   b) then 方法的回调函数如果不能执行,新的 promise 对象 和 调用 then 方法的 promise状态 完全一致
    
  3. 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 
    
			let p = new Promise((resolve, reject)=> {
				reject("ok")
			})
			let p2 = Promise.resolve(p)
			setTimeout(function(){
				console.log(p2)
			})
			Object.is(NaN, NaN)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值