博客
关于我
经典面试题目之: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/

你可能感兴趣的文章
nginx + etcd 动态负载均衡实践(四)—— 基于confd实现
查看>>
Nginx + Spring Boot 实现负载均衡
查看>>
Nginx + uWSGI + Flask + Vhost
查看>>
Nginx - Header详解
查看>>
Nginx - 反向代理、负载均衡、动静分离、底层原理(案例实战分析)
查看>>
nginx 1.24.0 安装nginx最新稳定版
查看>>
nginx 301 永久重定向
查看>>
nginx connect 模块安装以及配置
查看>>
nginx css,js合并插件,淘宝nginx合并js,css插件
查看>>
Nginx gateway集群和动态网关
查看>>
Nginx Location配置总结
查看>>
Nginx log文件写入失败?log文件权限设置问题
查看>>
Nginx Lua install
查看>>
nginx net::ERR_ABORTED 403 (Forbidden)
查看>>
Nginx SSL 性能调优
查看>>
Nginx SSL私有证书自签,且反代80端口
查看>>
Nginx upstream性能优化
查看>>
Nginx 中解决跨域问题
查看>>
nginx 代理解决跨域
查看>>
Nginx 做负载均衡的几种轮询策略分析
查看>>