当前位置: 首页 > article >正文

基于vue3+vite+axios的接口请求封装

一、src目录下新建http文件夹,文件夹下新建index.js/request.js文件以及api文件夹

二、reques.js文件封装请求方法

import axios from 'axios';
import qs from 'qs'

// 创建axios实例
const request = axios.create({
  baseURL: import.meta.env.VITE_BASE_URL,
  timeout: 1000000
});

request.interceptors.request.use(
  config => {
    config.headers['Content-Type'] = 'application/json'
    const token = sessionStorage.getItem('token') || ''
    if (token) {
        config.headers['Authorization'] = `Bearer ${token}`
    }
    return config;
  },
  error => {
    return Promise.reject(error);
  }
);

request.interceptors.response.use(
  response => {
    return response.data;
  },
  error => {
    return Promise.reject(error);
  }
);

let post = (url, param) => {
    return request({
        method: 'POST',
        url: `${url}?${qs.stringify(param)}`,
    })
}


let get = (url, params) => {
    return request({
        method: 'GET',
        url: `${url}${params}`,
    })
}

export { post, get }

三、index.js文件遍历api文件夹下的文件,引入请求方法,封装对象

import { post, get, postBody } from './request';
let baseMethod = {
    post,
    get
}

const transRequest = (apiObj) => {
    let res = {};
    for (const [key, value] of Object.entries(apiObj)) {
        console.log(key, value)
        const name = key
        const { method, url } = value
        if(value.hasOwnProperty('baseURL')){
            const baseURL = value.baseURL
            res[name] = (data, option) => baseMethod[method](url, data, baseURL, option)
        }else{
            res[name] = (data, option) => baseMethod[method](url, data, option)
        }
        
    }
    return res
}

// 遍历接口文件夹
function importApi() {
    const res = {};
    const modules = import.meta.glob('./api/*.js');
    for (const path in modules) {
        modules[path]().then((file) => {
            const api = transRequest(file)
            Object.assign(res, api)
        })
    }
    return res;
}

const ApiList = importApi();



export { ApiList } ;

四、api文件夹下根据模块化划分新建js文件

let loginApi = {
    method: 'post',
    url: '/login',
    des: '登录接口'
}


export {
    loginApi,
  
}

五、使用方式

import { ApiList } from '../http/index'

 let res = await ApiList.searchByTextApi({ keyword: text })


http://www.kler.cn/a/572674.html

相关文章:

  • Linux基础 -- `dlsym` 函数的作用
  • Redis maven项目 jedis 客户端操作(二)
  • 【电控笔记z69】电机选型-机械特性
  • 数据流图(实例)
  • 搜好货平台按关键字搜索商品API接口开发实战(Python版
  • 文本处理Bert面试内容整理-BERT的应用场景有哪些?
  • CSS 中等比例缩放的演变:从传统技巧到 aspect-ratio 属性
  • 宁波福尔达智能科技-再次续订MappingSpace
  • linux服务器根据内核架构下载各种软件依赖插件(例子:Anolis服务器ARM64架构内核Nginx依赖插件下载)
  • Adam优化器
  • kubectrl 使用多k8s 配置文件
  • 后端架构模式之-BFF(Backend-For-Frontend)
  • 国科大——数据挖掘(0812课程)——考试真题
  • ASP.NET Core JWT认证与授权
  • 【玩转正则表达式】将正则表达式中的分组(group)与替换进行结合使用
  • 深入C语言:指针与数组的经典笔试题剖析
  • 大语言模型(LLM)和嵌入模型的统一调用接口
  • 谈谈常用的分布式 ID 设计方案?
  • MySQL数据库只能通过localhost访问,无法通过IP访问?两步快速定位和解决
  • stm32主从机硬件IIC实现