【八股】介绍Promise(ES6引入)

Promise 是 JavaScript 中用于异步编程的一种非常重要的对象。它代表了一个异步操作的最终完成(或失败)及其结果值。以下是 Promise 的一些核心特性和应用:

出现--改进异步编程

  • 早期avaScript 的异步编程主要依赖于回调函数,容易导致"回调地狱"问题,代码难以阅读和维护。
  • Promise(ES6引入) 允许我们以近乎同步的方式编写异步代码,通过链式调用 .then().catch() 方法,显著提高了代码的可读性和可维护性。

状态和执行器函数

  • Promise 有三种状态:
    • Pending(进行中):异步操作未完成。
    • Fulfilled(已成功):异步操作成功完成,并且结果值就是成功的值。
    • Rejected(已失败):异步操作失败,并且原因已被抛出。
  • 这些状态反映了异步操作的当前状态,并且状态的改变是单向的:从 Pending 到 Resolved 或 Rejected,并且一旦状态改变,就不可再次更改。
  • 用new Promise构造函数,提供执行器函数:
    • resolve 在异步操作成功时调用,并且返回操作的结果。
    • **reject**在异步操作失败时调用,并且返回操作失败的原因。

应用场景

  • 在前端开发中,Promise 被广泛应用于各种场景,如 Axiosfetch API 等网络请求处理,以及文件上传、定时器等异步操作。

链式调用

  • 当存在多个依赖的异步操作时,Promise 允许我们以链式的方式进行异步操作,这样我们可以顺序执行多个异步操作,并且每个操作的结果可以作为下一个操作的输入

静态方法

  • Promise.all(iterable):等待多个 Promise 实例的完成。
  • Promise.race(iterable):只要有一个实例率先完成,就返回该实例的结果。
  • Promise.resolve(value):将一个成功的值包装成 Promise 对象。
  • Promise.reject(reason):将一个失败的原因包装成 Promise 对象。
  • 注意方法不能滥用,例如,使用 Promise.all 时,如果其中一个 Promise 失败,整个 Promise.all 调用都会失败。这可能导致一些数据加载失败,影响到整个流程的执行。

promise示例代码

javascript 复制代码
//创建Promise对象
const myPromise = new Promise((resolve, resolve) => {
    // 异步操作
    if (/* 操作成功 */) {
        resolve(value); // 正常完成
    } else {
        reject(error); // 失败
    }
});
  
//调用Promise实例的两个方法
  myPromise.then(value => {
    // 处理成功的值
}).catch(error => {
    // 处理错误
});

//链式调用--每个then可以返回一个新的Promise对象,被下一个then()接收
  myPromise
    .then(result => {
        // 第一个异步操作的结果
        return anotherAsyncOperation(result);
    })
    .then(newResult => {
        // 第二个异步操作的结果
        console.log(newResult);
    })
    .catch(error => {
        // 链式调用中任何地方出现的错误都会走到这里
        console.error(error);
    });

欢迎指正!

相关推荐
半桶水专家3 小时前
Vue 3 插槽(Slot)详解
前端·javascript·vue.js
袁煦丞3 小时前
本地AI绘画神器+全局访问——Stable Diffusion WebUI 成功突破:cpolar内网穿透实验室第462个成功挑战
前端·程序员·远程工作
一枚前端小能手3 小时前
🏗️ JavaScript类深度解析 - 从构造函数到现代特性的完整指南
前端·javascript
袁煦丞3 小时前
家用NAS+云盘自由NanoPi R4S+iStoreOS:cpolar内网穿透实验室第460个成功挑战
前端·程序员·远程工作
浏览器API调用工程师_Taylor3 小时前
日报自动化实战:告别手动复制粘贴
前端·javascript·node.js
晴殇i3 小时前
JavaScript还能这样写?!ES2025新语法让代码优雅到极致
前端·javascript·程序员
浏览器API调用工程师_Taylor3 小时前
我是如何将手动的日报自动化的☺️☺️☺️
前端·javascript·爬虫
前端Hardy4 小时前
HTML&CSS&JS:抖音爆火的满屏“关心弹幕”酷炫卡片,已经帮你打包好了,快来体验吧!
前端·javascript·css
江城开朗的豌豆4 小时前
我的Vue项目胖成球了!用Webpack给它狠狠瘦个身
前端·javascript
WebInfra4 小时前
Rspack 1.6 发布:让打包产物更小、更纯净
前端·javascript·前端框架