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);
})
相关推荐
wusp1994几秒前
理解JSON Web Token(JWT)及其在Node.js中的使用
前端·node.js·json·jwt
InterestingFigure9 分钟前
Java 使用sql查询mongodb
java·开发语言·数据库·sql·mongodb
Janebook10 分钟前
Java技术栈总结:Spring框架篇
java·开发语言
danielli12 分钟前
C# 开发Winform DataGridView的增删改查实战
开发语言·oracle·c#
特立独行的猫a14 分钟前
Pinia:Vue 2 和 Vue 3 中更好用的状态管理框架
前端·javascript·vue.js·pinia·vuex
香蕉你个不呐呐63517 分钟前
io流 多线程
java·开发语言
不爱敲代码的阿玲21 分钟前
C# —— 日期对象
开发语言·c#
武汉前端开发蓝风22 分钟前
纯前端低代码开发脚手架 - daelui/molecule
前端·低代码
zhendianluli27 分钟前
Python的多态
开发语言·python
捕风捉你29 分钟前
状态模式在金融业务中的应用及其框架实现
java·开发语言·状态模式