博客
关于我
经典面试题目之:promise
阅读量:341 次
发布时间:2019-03-04

本文共 1356 字,大约阅读时间需要 4 分钟。

promise

1、为什么使用promise

避免界面冻结

同步:假设你去了一家饭店,找个位置,叫来服务员,这个时候服务员对你说,对不起我是“同步”服务员,我要服务完这张桌子才能招呼你。那桌客人明明已经吃上了,你只是想要个菜单,这么小的动作,服务员却要你等到别人的一个大动作完成之后,才能再来招呼你,这个便是同步的问题:也就是“顺序交付的工作1234,必须按照1234的顺序完成”。

异步:则是将耗时很长的A交付的工作交给系统之后,就去继续做B交付的工作,。等到系统完成了前面的工作之后,再通过回调或者事件,继续做A剩下的工作。

AB工作的完成顺序,和交付他们的时间顺序无关,所以叫“异步”。

2、promise是什么

promise是一个对象,对象和函数的区别就是对象可以保存状态,函数不可以,promise并未剥夺函数return的能力,因此无需层层传递callback,进行回调获取数据,多个异步等待合并便于解决。

代码:

new Promise(  function (resolve, reject) {    // 一段耗时的异步操作    resolve('成功') // 数据处理完成    // reject('失败') // 数据处理出错  }).then(  (res) => {console.log(res)},  // 成功  (err) => {console.log(err)} // 失败)

resolve:将Promise对象的状态从“未完成”变为“成功”,在异步操作成功时调用,并将异步操作的结果,作为参数传递出去;

reject:将Promise对象的状态从“未完成”变为“失败”(即从 pending 变为 rejected),在异步操作失败时调用,并将异步操作报出的错误,作为参数传递出去。

3、三个状态

1、pending[待定]初始状态

2、fulfilled[实现]操作成功
3、rejected[被否决]操作失败

​ 当promise状态发生改变,就会触发then()里的响应函数处理后续步骤;Promise对象的状态改变,只有两种可能:

  • 从pending变为fulfilled
  • 从pending变为rejected

实例1:

new Promise(resolve => {  setTimeout(() => {    resolve('hello')  }, 2000)}).then(res => {  console.log(res)})

实例2:

new Promise(resolve => {    setTimeout(() => {      resolve('hello')    }, 2000)  }).then(val => {    console.log(val) //  参数val = 'hello'    return new Promise(resolve => {      setTimeout(() => {        resolve('world')      }, 2000)    })  }).then(val => {    console.log(val) // 参数val = 'world'  })

转载地址:http://fase.baihongyu.com/

你可能感兴趣的文章
MSSQL数据库查询优化(一)
查看>>
MSSQL数据库迁移到Oracle(二)
查看>>
MSSQL日期格式转换函数(使用CONVERT)
查看>>
MSTP多生成树协议(第二课)
查看>>
MSTP是什么?有哪些专有名词?
查看>>
Mstsc 远程桌面链接 And 网络映射
查看>>
Myeclipse常用快捷键
查看>>
MyEclipse更改项目名web发布名字不改问题
查看>>
MyEclipse用(JDBC)连接SQL出现的问题~
查看>>
mt-datetime-picker type="date" 时间格式 bug
查看>>
myeclipse的新建severlet不见解决方法
查看>>
MyEclipse设置当前行背景颜色、选中单词前景色、背景色
查看>>
Mtab书签导航程序 LinkStore/getIcon SQL注入漏洞复现
查看>>
myeclipse配置springmvc教程
查看>>
MyEclipse配置SVN
查看>>
MTCNN 人脸检测
查看>>
MyEcplise中SpringBoot怎样定制启动banner?
查看>>
MyPython
查看>>
MTD技术介绍
查看>>
MySQL
查看>>