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);
})
相关推荐
yngsqq8 分钟前
c#使用高版本8.0步骤
java·前端·c#
流星白龙10 分钟前
【C++习题】10.反转字符串中的单词 lll
开发语言·c++
尘浮生18 分钟前
Java项目实战II基于微信小程序的校运会管理系统(开发文档+数据库+源码)
java·开发语言·数据库·微信小程序·小程序·maven·intellij-idea
MessiGo18 分钟前
Python 爬虫 (1)基础 | 基础操作
开发语言·python
Tech Synapse24 分钟前
Java根据前端返回的字段名进行查询数据的方法
java·开发语言·后端
乌啼霜满天24932 分钟前
JDBC编程---Java
java·开发语言·sql
Myli_ing42 分钟前
考研倒计时-配色+1
前端·javascript·考研
色空大师1 小时前
23种设计模式
java·开发语言·设计模式
余道各努力,千里自同风1 小时前
前端 vue 如何区分开发环境
前端·javascript·vue.js
PandaCave1 小时前
vue工程运行、构建、引用环境参数学习记录
javascript·vue.js·学习