设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 重新 试卷 文件
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

JS异步编程六种方案(2)

发布时间:2019-01-22 05:32 所属栏目:21 来源:浪里行舟
导读:1.Promise的三种状态 Pending----Promise对象实例创建时候的初始状态 Fulfilled----可以理解为成功的状态 Rejected----可以理解为失败的状态 这个承诺一旦从等待状态变成为其他状态就永远不能更改状态了,比如说一

1.Promise的三种状态

  •  Pending----Promise对象实例创建时候的初始状态
  •  Fulfilled----可以理解为成功的状态
  •  Rejected----可以理解为失败的状态

JS异步编程六种方案

这个承诺一旦从等待状态变成为其他状态就永远不能更改状态了,比如说一旦状态变为 resolved 后,就不能再次改变为Fulfilled

  1. let p = new Promise((resolve, reject) => {  
  2.   reject('reject')  
  3.   resolve('success')//无效代码不会执行  
  4. })  
  5. p.then(  
  6.   value => {  
  7.     console.log(value)  
  8.   },  
  9.   reason => {  
  10.     console.log(reason)//reject  
  11.   }  

当我们在构造 Promise 的时候,构造函数内部的代码是立即执行的

  1. new Promise((resolve, reject) => {  
  2.   console.log('new Promise')  
  3.   resolve('success')  
  4. })  
  5. console.log('end')  
  6. // new Promise => end 

2.promise的链式调用

  •  每次调用返回的都是一个新的Promise实例(这就是then可用链式调用的原因)
  •  如果then中返回的是一个结果的话会把这个结果传递下一次then中的成功回调
  •  如果then中出现异常,会走下一个then的失败回调
  •  在 then中使用了return,那么 return 的值会被Promise.resolve() 包装(见例1,2)
  •  then中可以不传递参数,如果不传递会透到下一个then中(见例3)
  •  catch 会捕获到没有捕获的异常

接下来我们看几个例子:

  1. // 例1  
  2. Promise.resolve(1)  
  3. .then(res => {  
  4.   console.log(res)  
  5.   return 2 //包装成 Promise.resolve(2)  
  6. })  
  7. .catch(err => 3)  
  8. .then(res => console.log(res))  
  1. // 例2  
  2. Promise.resolve(1)  
  3.   .then(x => x + 1)  
  4.   .then(x => {  
  5.     throw new Error('My Error')  
  6.   })  
  7.   .catch(() => 1)  
  8.   .then(x => x + 1)  
  9.   .then(x => console.log(x)) //2  
  10.   .catch(console.error)  
  1. // 例3  
  2. let fs = require('fs')  
  3. function read(url) {  
  4.   return new Promise((resolve, reject) => {  
  5.     fs.readFile(url, 'utf8', (err, data) => {  
  6.       if (err) reject(err)  
  7.       resolve(data)  
  8.     })  
  9.   })  
  10. }  
  11. read('./name.txt')  
  12.   .then(function(data) {  
  13.     throw new Error() //then中出现异常,会走下一个then的失败回调  
  14.   }) //由于下一个then没有失败回调,就会继续往下找,如果都没有,就会被catch捕获到  
  15.   .then(function(data) {  
  16.     console.log('data')  
  17.   })  
  18.   .then()  
  19.   .then(null, function(err) {  
  20.     console.log('then', err)// then error  
  21.   })  
  22.   .catch(function(err) {  
  23.     console.log('error')  
  24.   }) 

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读