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

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

Promise

为什么使用Promise

Promise是一种解决异步编程的技术,它能够帮助我们避免界面冻结,并提高程序的执行效率。

在传统的同步代码中,如果一个操作耗时较长,会阻塞后续代码的执行,导致界面失去响应。例如,假设你正在等待一张桌子的服务完成,其他客人可能需要等待很长时间才能得到服务。这就是同步编程的问题。

而异步编程则不同,它允许我们将耗时较长的操作交给系统处理,继续执行其他任务。当系统完成前面的操作后,会通过回调或者事件来通知我们,可以继续处理剩下的工作。这样,AB两个任务的执行顺序和完成时间就不再相关了,这就是所谓的“异步”。

Promises是什么

Promises是一个对象,它能够帮助我们处理异步操作,并通过回调的方式来获取结果。与传统的回调函数不同,Promises允许我们将多个异步操作进行合并处理,简化了代码结构。

Promises通过`resolve`和`reject`两个参数来管理状态。当异步操作成功完成时,`resolve`会将Promise状态从“未完成”变为“成功”,并传递结果;如果操作失败,`reject`会将状态变为“失败”,并传递错误信息。

代码示例:

```javascriptnew Promise(function(resolve, reject) { // 执行耗时的异步操作 resolve('成功'); // 数据处理完成}).then(function(res) { console.log(res); // 输出结果}, function(err) { console.log(err); // 处理错误});```

Promises的三个状态

Promises的状态分为三个阶段:

1. **Pending(待定)**:这是Promise的初始状态,表示操作尚未开始处理。 2. **Fulfilled(实现)**:表示操作成功完成,状态变为“成功”。 3. **Rejected(被否决)**:表示操作失败,状态变为“失败”。

一旦Promise的状态发生改变,就会触发`.then()`方法中的回调函数,处理后续步骤。

示例:

```javascriptnew Promise(resolve => { setTimeout(() => { resolve('hello'); }, 2000);}).then(res => { console.log(res); // 输出 'hello'});```

另一个示例:

```javascriptnew Promise(resolve => { setTimeout(() => { resolve('hello'); }, 2000);}).then(val => { console.log(val); // 输出 'hello' return new Promise(resolve => { setTimeout(() => { resolve('world'); }, 2000); });}).then(val => { console.log(val); // 输出 'world'});```

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

你可能感兴趣的文章
OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
查看>>
OAuth2.0_授权服务配置_三项内容_Spring Security OAuth2.0认证授权---springcloud工作笔记141
查看>>
OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
查看>>
OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
查看>>
OAuth2.0_授权服务配置_密码模式及其他模式_Spring Security OAuth2.0认证授权---springcloud工作笔记145
查看>>
OAuth2.0_授权服务配置_授权码模式_Spring Security OAuth2.0认证授权---springcloud工作笔记144
查看>>
OAuth2.0_授权服务配置_资源服务测试_Spring Security OAuth2.0认证授权---springcloud工作笔记146
查看>>
OAuth2.0_环境介绍_授权服务和资源服务_Spring Security OAuth2.0认证授权---springcloud工作笔记138
查看>>
OAuth2.0_环境搭建_Spring Security OAuth2.0认证授权---springcloud工作笔记139
查看>>
oauth2.0协议介绍,核心概念和角色,工作流程,概念和用途
查看>>
OAuth2.0四种模式的详解
查看>>
OAuth2授权码模式详细流程(一)——站在OAuth2设计者的角度来理解code
查看>>
oauth2登录认证之SpringSecurity源码分析
查看>>
OAuth2:项目演示-模拟微信授权登录京东
查看>>
OA系统多少钱?OA办公系统中的价格选型
查看>>
OA系统选型:选择好的工作流引擎
查看>>
OA让企业业务流程管理科学有“据”
查看>>
OA项目之会议通知(查询&是否参会&反馈详情)
查看>>
Vue.js 学习总结(13)—— Vue3 version 计数介绍
查看>>
OA项目之我的会议(会议排座&送审)
查看>>