vue3+vite+js axios引用

先交代下基础版本:
"node":"V16.14.1" "vue": "^3.4.21" "vite": "^5.2.0"

  1. 安装:npm install axios --save

  2. 在src目录下的utils 文件夹创建一个request.js文件(示例代码,仅供参考):

    //引入axios请求
    import axios from 'axios'
    // store
    import useUserStore from '@/store/modules/userStore.js'
    const store = useUserStore()
    const BASE_API=import.meta.env.VITE_APP_BASE_API
    // 创建axios实例
    const service = axios.create({
    baseURL: BASE_API, //所有的后端接口请求地址前缀部分(没有后端请求不用写)
    timeout: 15000 // 请求超时时间,这里15秒
    //withCredentials: true,// 异步请求携带cookie,true为携带,false为不携带
    //请求头里面设置通用传参类型
    /headers: {
    //设置后端需要的传参类型
    'Content-Type': 'application/json',
    'token': 'x-auth-token',//一开始就要token
    'X-Requested-With': 'XMLHttpRequest',
    }
    /
    })

    // request拦截器
    service.interceptors.request.use(config => {
    const value = JSON.parse(localStorage.getItem('token'));
    console.log(111, value.token)
    if (store.token) {
    config.headers['token'] = store.token // 让每个请求携带自定义token 请根据实际情况自行修改
    }
    return config
    }, error => {
    console.log(error)
    return Promise.reject(error)
    })

    // response拦截器
    service.interceptors.response.use(
    response => {
    //对数据返回做什么
    const res = response.data
    const config = response.config
    // custom 表示自定义
    if (res.status_code !== 200 && !config.custom) {
    // if (res.status_code === 1002) {
    // loginOut()
    // } else if (loginVerify(res, config)) { // 登录功能验证
    // return res
    // } else {
    // Message({
    // message: res.status || 'Error',
    // type: 'error',
    // duration: 5 * 1000
    // })
    // }
    return Promise.reject(new Error(res.status || 'Error'))
    } else {
    if (response.headers['authorization'] || response.headers['Authorization']) {
    const _token = response.headers['authorization'] || response.headers['Authorization']
    store.dispatch('user/setToken', _token.split('Bearer ')[1])
    }
    return res
    }
    },
    error => {
    console.log('err' + error) // for debug
    // Message({
    // message: error.message,
    // type: 'error',
    // duration: 5 * 1000
    // })
    return Promise.reject(error)
    }
    )
    export default service

  3. src 目录下创建一个api斜体样式文件夹,用来存放每个模块的接口请求,类如login.js

    import request from '@/utils/request'

    //示例以application/json格式传参
    export function login(data) {
    return request({
    url: '/admin/login',
    method: 'post',
    data: data
    })
    }

    //示例在url后面拼接参数传参
    export function test(params) {
    return request({
    url: '/admin/login',
    method: 'post',
    params: params
    })
    }

  4. 使用,类如HelloWorld.vue:

    <script setup> import { login } from '@/api/login.js' onMounted(() => { login({ phone: 18888888888 }).then(res => { console.log(res) }).catch(res => { console.log(res) }) }) </script>
相关推荐
yinuo2 小时前
前端跨页面通讯终极指南⑥:SharedWorker 用法全解析
前端
PineappleCoder6 小时前
还在重复下载资源?HTTP 缓存让二次访问 “零请求”,用户体验翻倍
前端·性能优化
拉不动的猪7 小时前
webpack编译中为什么不建议load替换ast中节点删除consolg.log
前端·javascript·webpack
李姆斯7 小时前
Agent时代下,ToB前端的UI和交互会往哪走?
前端·agent·交互设计
源码获取_wx:Fegn08957 小时前
基于springboot + vue健身房管理系统
java·开发语言·前端·vue.js·spring boot·后端·spring
闲谈共视7 小时前
基于去中心化社交与AI智能服务的Web钱包商业开发的可行性
前端·人工智能·去中心化·区块链
CreasyChan7 小时前
C# 反射详解
开发语言·前端·windows·unity·c#·游戏开发
JIngJaneIL8 小时前
基于Java+ vue智慧医药系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
+VX:Fegn08958 小时前
计算机毕业设计|基于springboot + vue图书管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
阿蒙Amon9 小时前
JavaScript学习笔记:6.表达式和运算符
javascript·笔记·学习