Promise的使用,及使用Promise封装axios

Promise的使用,及使用Promise封装axios

Promise是什么?

Promise是JavaScript中用于处理异步操作的一种编程模式。它是一种表示异步操作最终完成或失败的对象。

一个Promise对象可以处于以下三种状态之一:

  • Pending(进行中):初始状态,表示异步操作尚未完成。
  • Fulfilled(已完成):表示异步操作成功完成。
  • Rejected(已拒绝):表示异步操作失败。

当一个Promise处于Pending状态时,它可以转变为Fulfilled状态或Rejected状态。一旦转变为其中一种状态,Promise的状态就不会再改变。

Promise对象提供了一个.then()方法,用于添加异步操作成功后的回调函数,并返回一个新的Promise对象。这使得我们可以通过链式调用.then()来处理多个异步操作的顺序执行。

Promise也提供了.catch()方法,用于添加异步操作失败后的错误处理回调函数。

还有.finally()方法,无论Promise对象最终处于Fulfilled还是Rejected状态,都会执行该方法中定义的逻辑。

Promise的使用

js 复制代码
const myPromise = new Promise((resolve, reject) => {
  // 异步操作的代码

  if (/* 异步操作成功 */) {
    resolve(result);  // 将Promise状态改为Fulfilled,并传递结果
  } else {
    reject(error);  // 将Promise状态改为Rejected,并传递错误信息
  }
});

myPromise.then((result) => {
  // 异步操作成功后的处理逻辑
}).catch((error) => {
  // 异步操作失败后的错误处理逻辑
}).finally(() => {
  // 无论Promise最终的状态是成功还是失败,都会执行的逻辑
});

通过使用Promise,我们可以更好地处理异步操作,并提供清晰的控制流程和错误处理机制。

使用Promise封装请求

下面的示例封装了几个商品相关的接口

js 复制代码
// 文件路径: /api/shop.js
import axios from 'axios';
import qs from 'qs';
// 商品列表
export const shopList = () => {
  return new Promise((resolve, reject) => {
    axios({
      url: '/api/shop/list',
      method: 'GET',
    }).then(res => {
      let data = res.data;
      // 请求成功
      if (data.code == 1) {
        resolve(data)// 将Promise状态改为Fulfilled,并传递结果
      } else {
        reject(data)// 将Promise状态改为Rejected,并传递错误信息
      }
    })
  })
}
// 商品添加,接收参数data
export const shopAdd = (data) => {
  return new Promise((resolve, reject) => {
    axios({
      url: '/api/shop/add',
      method: 'POST',
      data: qs.stringify(data)
    }).then(res => {
      let data = res.data;
      // 请求成功
      if (data.code == 1) {
        resolve(data)// 将Promise状态改为Fulfilled,并传递结果
      } else {
        reject(data)// 将Promise状态改为Rejected,并传递错误信息
      }
    })
  })
}
// 商品删除,接收参数data
export const shopDel = (data) => {
  return new Promise((resolve, reject) => {
    axios({
      url: '/api/shop/add',
      method: 'POST',
      data: qs.stringify(data)
    }).then(res => {
      let data = res.data;
      // 请求成功
      if (data.code == 1) {
        resolve(data)// 将Promise状态改为Fulfilled,并传递结果
      } else {
        reject(data)// 将Promise状态改为Rejected,并传递错误信息
      }
    })
  })
}

在需要的页面进行使用

js 复制代码
import { shopList, shopAdd, shopDel } from '@/api/shop.js';
// 商品列表
shopList().then(res => {
  // 处理逻辑
  console.log(res);
})
// 商品添加
shopAdd({ title: '商品名称', price: 100 }).then(res => {
  // 处理逻辑
  console.log(res);
})
// 商品删除
shopDel({ id: 1 }).then(res => {
  // 处理逻辑
  console.log(res);
})
相关推荐
小研说技术1 分钟前
实时通信对比,一场MCP协议的技术革命
前端·后端·面试
一行代码一行诗++2 分钟前
C语言中scanf详解
c语言·开发语言
凤山老林5 分钟前
26-Java this 关键字
java·开发语言
kyriewen5 分钟前
React Hooks原理:为什么不能写在if里?揭开Hook的“魔法”面纱
前端·react.js·前端框架
敲代码的彭于晏8 分钟前
Claude Code Token 烧得太快?这8个方案帮你立省90%!
前端·ai编程·claude
可视之道10 分钟前
设备拓扑图中的实时状态映射与动画策略:告警闪烁、流向动画、质量码怎么共存
前端
涂兵兵_青石疏影11 分钟前
绘制图像-clip方法
前端
ZenosDoron11 分钟前
keil软件修改字体,Asm editor,和C/C++ editor的区别
c语言·开发语言·c++
之歆26 分钟前
Day03_HTML 列表、表格、表单完整指南(下)
android·javascript·html
焦糖玛奇朵婷29 分钟前
解锁扭蛋机小程序的五大优势
java·大数据·服务器·前端·小程序