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>

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

相关推荐
Aress"12 分钟前
uniapp设置vuex公共值状态管理
javascript·vue.js·uni-app
东芃939416 分钟前
uniapp上传blob对象到后台
前端·javascript·uni-app
coding随想34 分钟前
救命!网页还在偷偷耗电?浏览器Battery API事件教你精准控电,这5个场景用了都说香
前端
贝西奇谈39 分钟前
JavaScript DOM节点操作详解
开发语言·javascript·php
IT_陈寒1 小时前
Redis性能翻倍的5个冷门优化技巧,90%的开发者都不知道第3个!
前端·人工智能·后端
华仔啊1 小时前
无需UI库!50行CSS打造丝滑弹性动效导航栏,拿来即用
前端·css
光影34152 小时前
专利撰写与申请核心要点简报
前端·数据库·php
ze_juejin2 小时前
Angular 中设置宿主元素(Host)样式的方法
前端
用户90443816324602 小时前
《零代码基础也能 AI 创作?GPT+DALL・E 实战教程,10 分钟上手》
前端·github
WillaWang2 小时前
aria | "Accessible Rich Internet Applications"
前端