Vue 中简易封装网络请求(Axios),包含请求拦截器和响应拦截器

Vue 中简易封装网络请求(Axios),包含请求拦截器和响应拦截器

axios简介

Axios 是一个基于 promise 的网络请求库,可以用于浏览器和 node.js

Axios官方中文文档

特性

  • 从浏览器创建 XMLHttpRequests
  • 从 node.js 创建 http 请求
  • 支持 Promise API
  • 拦截请求和响应
  • 转换请求和响应数据
  • 取消请求
  • 超时处理
  • 查询参数序列化支持嵌套项处理
  • 自动将请求体序列化为:
    JSON (application/json)
    Multipart / FormData (multipart/form-data)
    URL encoded form (application/x-www-form-urlencoded)
  • 将 HTML Form 转换成 JSON 进行请求
  • 自动转换JSON数据
  • 获取浏览器和 node.js 的请求进度,并提供额外的信息(速度、剩余时间)
  • 为 node.js 设置带宽限制
  • 兼容符合规范的 FormData 和 Blob(包括 node.js)
  • 客户端支持防御XSRF

安装

复制代码
npm install axios;

示例代码

https.js

javascript 复制代码
import axios from "axios";
// const token = localStorage.getItem("accessToken");

export const https = axios.create({
  baseURL: "http://localhost:3000",
  timeout: 15000,
  headers: {},
});

// 添加请求拦截器
https.interceptors.request.use(
  (config) => {
    // 在发送请求之前做些什么
    // if (token) {
    //   config.headers.accessToken = `Bearer ${token}`;
    // }
    return config;
  },
  (error) => {
    // 对请求错误做些什么
    // console.log(error);
    return Promise.reject(error);
  }
);

// 添加响应拦截器
https.interceptors.response.use(
  (response) => {
    // 2xx 范围内的状态码都会触发该函数。
    // 对响应数据做点什么
    // console.log(response);
    if (response.status === 200) {
      // console.log(Promise.resolve(response));
      return Promise.resolve(response);
    } else {
      return Promise.reject(response);
    }
    // return response;
  },
  (error) => {
    // 超出 2xx 范围的状态码都会触发该函数。
    console.log(error);
    // 对响应错误做点什么
    return Promise.reject(error);
  }
);

在Vue中引入使用

javascript 复制代码
import { https } from "@/api/http";
//GET请求
// 写过的一个分页查询为例
https
  .get("/display", {
    params: {
      pageSize: page.pageSize.value,
      currentPage: page.currentPage.value,
    },
  })
  .then((res) => {
    console.log(res);
  })
  .catch((error) => {
    console.log(error);
  });
  // 另一种写法
 https.get("/display?ID=12345")
  .then((res) => {
    console.log(res);
  })
  .catch((error) => {
    console.log(error);
  });
 
//POST请求
https
  .post("/display", {
  	id: id.value,
  })
  .then((res) => {
    console.log(res);
  })
  .catch((error) => {
    console.log(error);
  });
相关推荐
Sahadev_17 小时前
做APP开发有哪些基建可以做?完整调试工具集实践指南(以ReactNative为例)
javascript·react native·react.js
阿民不加班17 小时前
【React】使用browser-image-compression在上传前压缩图片、react上传图片压缩
前端·javascript·react.js
前端_yu小白17 小时前
前端实现录音,获取流分析音量大小,设置相应的动画
前端·mediarecorder·录音·浏览器安全性检查·https部署
虎子_layor17 小时前
小程序登录到底是怎么工作的?一次请求背后的三方信任链
前端·后端
草字17 小时前
css 父节点设置display: flex; align-items: center;,子节点如何跟随其他子节点撑高的高度
前端·javascript·css
前端_yu小白18 小时前
websocket在vue项目和nginx中的代理配置
vue.js·websocket·nginx·vue3·服务端推送
我命由我1234518 小时前
微信小程序 - 页面跳转并传递参数(使用路由参数、使用全局变量、使用本地存储、使用路由参数结合本地存储)
开发语言·前端·javascript·微信小程序·小程序·前端框架·js
DJ斯特拉18 小时前
日志技术Logback
java·前端·logback
+VX:Fegn089518 小时前
计算机毕业设计|基于springboot + vue二手交易管理系统(源码+数据库+文档)
数据库·vue.js·spring boot
HIT_Weston18 小时前
49、【Ubuntu】【Gitlab】拉出内网 Web 服务:http.server 单/多线程分析(一)
前端·ubuntu·gitlab