vue3封装接口(自测可用)

注:别忘记安装axios

在实际的项目实战中如果我们不对接口加以管理,整篇看着就很乱,这个时候我们就要用到接口封装了。

废话不多说直接上代码!!!

首先是request.js

复制代码
import axios from "axios";

// 使用环境变量来设置基础URL
const baseURL = process.env.VUE_APP_API_BASE_URL || "接口前缀http://xxxxxxxxxxxxxx";

const service = axios.create({
  baseURL: baseURL,
  timeout: 5000,
  headers: {
    "Content-type": "application/json;charset=utf-8"
  }
});

service.interceptors.request.use(config => {
  const token = localStorage.getItem("token");
  if (token) {
    config.headers['Authorization'] = 'Bearer ' + token;
  }
  return config;
}, error => {
  console.error("Request error: ", error);
  return Promise.reject(error);
});

service.interceptors.response.use(response => {
  if (response.status === 200) {
    return response.data;
  } else {
    // 可以根据需要添加更多的错误处理
    console.error("Response error: ", response);
    return Promise.reject(new Error("Error with status code " + response.status));
  }
}, error => {
  // 对常见的HTTP错误进行处理
  if (error.response) {
    // 请求已发出,服务器回复状态码不在2xx范围
    console.error("Error status: ", error.response.status);
    // 根据返回的状态码进行不同的处理
    // 例如: if (error.response.status === 401) { // 处理登录过期 }
  } else {
    // 服务器连回应都没有返回
    console.error("Network error: ", error);
  }
  return Promise.reject(error);
});

export default service;

其次api.js

post方法

复制代码
// 我要用到的一些接口
import service from "@/request/index";
// 引入接口
// 如果在 JavaScript 中引入接口不需要进行类型标注
// import { ILoginData } from "@/type/login";

// 登录接口
export function index(data) {
    return service({
        url: "/index/index",
        method: "POST",
        data: data
    });
}

get方法

复制代码
export function index(queryParams) {
    return service({
        url: "/index/index",
        method: "GET",
        params: queryParams
    });
}

然后home.vue

到这里就非常简单了,直接import引入相应的名称在使用就可以了

复制代码
<template>
  <div>
    <div @click="inds">加载数据</div>

  </div>
</template>

<script setup>
import { ref } from 'vue';
import { index } from "@/request/api";



const inds = async () => {
  try {
    const res = await index();
    console.log(1, res);
  } catch (err) {
    console.error(2, err);
   
  } finally {
    console.log(3);
  }
};
</script>

最后封装接口请求数据

首页不需要参数,可以直接请求,那么需要参数的怎么办呢?有方法

这两种方法都行没什么不一样的

方法一

复制代码
<script setup>
import { ref } from 'vue';
import { index } from "@/request/api";



const inds = async () => {
  try {
    let id = 1119;//比如接口需要id就声明id,如果是name就写name
    const res = await index({id});
    console.log(1, res);
  } catch (err) {
    console.error("失败", err);
   
  } 
};
</script>

方法二

复制代码
<script setup>
import { ref } from 'vue';
import { index } from "@/request/api";



const inds = async () => {
  try {
    const res = await index({id:1119});
    console.log(1, res);
  } catch (err) {
    console.error("失败", err);
   
  } 
};
</script>

到这里就结束了感谢观看,有疑问可以在评论区写出来。

相关推荐
小兵张健7 小时前
价值1000的 AI 工作流:Codex 通用前端协作模式
前端·aigc·ai编程
sunny_7 小时前
面试踩大坑!同一段 Node.js 代码,CJS 和 ESM 的执行顺序居然是反的?!99% 的人都答错了
前端·面试·node.js
拉不动的猪8 小时前
移动端调试工具VConsole初始化时的加载阻塞问题
前端·javascript·微信小程序
ayqy贾杰9 小时前
Agent First Engineering
前端·vue.js·面试
IT_陈寒10 小时前
SpringBoot实战:5个让你的API性能翻倍的隐藏技巧
前端·人工智能·后端
iceiceiceice10 小时前
iOS PDF阅读器段评实现:如何从 PDFSelection 精准还原一个自然段
前端·人工智能·ios
大金乄10 小时前
封装一个vue2的elementUI 表格组件(包含表格编辑以及多级表头)
前端·javascript
葡萄城技术团队11 小时前
【性能优化篇】面对万行数据也不卡顿?揭秘协同服务器的“片段机制 (Fragments)”
前端
程序员阿峰11 小时前
2026前端必备:TensorFlow.js,浏览器里的AI引擎,不写Python也能玩转智能
前端
Jans11 小时前
Shipfe — Rust 写的前端静态部署工具:一条命令上线 + 零停机 + 可回滚 + 自动清理
前端