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

你可能感兴趣的文章
NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
查看>>
NLP_什么是统计语言模型_条件概率的链式法则_n元统计语言模型_马尔科夫链_数据稀疏(出现了词库中没有的词)_统计语言模型的平滑策略---人工智能工作笔记0035
查看>>
NLP、CV 很难入门?IBM 数据科学家带你梳理
查看>>
NLP三大特征抽取器:CNN、RNN与Transformer全面解析
查看>>
NLP入门(六)pyltp的介绍与使用
查看>>
NLP学习笔记:使用 Python 进行NLTK
查看>>
NLP度量指标BELU真的完美么?
查看>>
NLP的不同研究领域和最新发展的概述
查看>>
NLP的神经网络训练的新模式
查看>>
NLP采用Bert进行简单文本情感分类
查看>>
NLP问答系统:使用 Deepset SQUAD 和 SQuAD v2 度量评估
查看>>
NLP项目:维基百科文章爬虫和分类【02】 - 语料库转换管道
查看>>
NLP:从头开始的文本矢量化方法
查看>>
NLP:使用 SciKit Learn 的文本矢量化方法
查看>>
NLTK - 停用词下载
查看>>
nmap 使用总结
查看>>
nmap 使用方法详细介绍
查看>>
nmap使用
查看>>
nmap使用实战(附nmap安装包)
查看>>
Nmap哪些想不到的姿势
查看>>