vue3.0 axios请求封装(vue2.0也适合)

1.引入axios

npm install axios

2.src下面创建utils文件夹(下图)
在这里插入图片描述

service.js

import axios from "axios";
import { ElMessage } from "element-plus";
import { ElLoading } from "element-plus";
import store from "../store/index";

let loadingObj = null;
const Service = axios.create({
    timeout: 8000,
    baseURL: "https://xxx",
    headers: {
        "Content-type": "application/json;charset=utf-8",
        "Authorization": store.state.uInfo.userInfo.token,
    },
});
Service.interceptors.request.use((request) => {
    loadingObj = ElLoading.service({
        lock: true,
        text: "Loading",
        background: "rgba(0, 0, 0, 0.7)",
    });
    return request;
});

Service.interceptors.response.use(response => {
    loadingObj.close();
    return response.data;
}, error => {
    loadingObj.close();
    ElMessage({
        message: error.meta.msg,
        type: "error",
        duration: 2000,
    });
}
);

export const post = (config) => {
    return Service({
        ...config,
        method: "post",
        data: config.data,
    });
};

export const get = (config) => {
    return Service({
        ...config,
        method: "get",
        params: config.data,
    });
};

src/api/loginApi.js

import { post, get } from "@/utils/service";
const loginApi = {
  login(data) {
    return post({
      url: "api/login",
      data,
    });
  },
  getList(data) {
    return get({
      url: "/list",
      data,
    });
  },
};
export default loginApi;

页面引用

import loginApi from "@/api/loginApi";

setup中调用

        const submitForm = () => {
            loginApi.login(data.loginData).then(res => {
                store.commit('setUserInfo', res.data);
                localStorage.setItem('userInfo', JSON.stringify(res.data));
                router.push({
                    path: '/user'
                });
            });
        };
        return {
            ...toRefs(data),
            submitForm
        };
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值