记录:VUE3中本地mock和线上请求

request.ts

import axios, { InternalAxiosRequestConfig, AxiosResponse } from "axios";
import { useUserStoreHook } from "@/store/modules/user";
import { ElMessage, ElMessageBox } from 'element-plus'

// 创建 axios 实例
let serviceParams = {
    baseURL: '',
    timeout: 50000,
    headers: { "Content-Type": "application/json;charset=utf-8" }
};

// 导出 axios 实例
export default function request (options:any, defaultParams?:any) {
    return new Promise<any>((resolve, reject) => {
        if(defaultParams){
            serviceParams.baseURL = defaultParams
        } else {
            serviceParams.baseURL = import.meta.env.VITE_APP_BASE_API;
        };
        const service = axios.create(serviceParams);
        // 请求拦截器
        service.interceptors.request.use(
            (config: InternalAxiosRequestConfig<any>) => {
                const accessToken = localStorage.getItem("accessToken");
                if (accessToken) {
                    config.headers.Authorization = accessToken;
                    config.headers.Token = accessToken;
                }
                return config;
            },
            (error: any) => {
                console.log('请求错误拦截:', error);
                return Promise.reject(error);
            }
        );

        // 响应拦截器
        service.interceptors.response.use(
            (response: AxiosResponse<any>) => {
                const { code, msg } = response.data;
                if (code === 0) {
                    return response.data;
                }
                // 响应数据为二进制流处理(Excel导出)
                if (response.data instanceof ArrayBuffer) {
                    return response;
                }
                // 异常处理
                let tips = '';
                if (code === -1) {
                    tips = '服务器异常,稍后再试';
                } else if (code === 1013) {
                    tips = msg;
                } else {
                    tips = '系统未知错误';
                };
                console.log('响应异常拦截:', code, msg);
                ElMessage.error(tips);
                return Promise.reject(new Error(tips));
            },
            (error: any) => {
                if (error.response.data) {
                    const { code, msg } = error.response.data;
                    // token 过期,重新登录
                    if (code === "A0230") {
                        ElMessageBox.confirm("当前页面已失效,请重新登录", "提示", {
                            confirmButtonText: "确定",
                            type: "warning",
                        }).then(() => {
                            const userStore = useUserStoreHook();
                            userStore.resetToken().then(() => {
                                location.reload();
                            });
                        });
                    } else {
                        let tips = '';
                        if (error.message.indexOf('timeout') != -1) {
                            tips = '网络请求超时';
                        } else if (error.message == 'Network Error') {
                            tips = '网络连接错误,请检查您的网络';
                        } else {
                            tips = '服务器异常,稍后再试';
                        }
                        console.log('响应错误拦截:', code, msg);
                        ElMessage.error(tips);
                    }
                }
                return Promise.reject(error.message);
            }
        );
        service(options, defaultParams).then(res => {
            resolve(res);
        }).catch(error => {
            reject(error)
        })
    })
};

api.ts

import request from "@/utils/request";
import { AxiosPromise } from "axios";
import { IcpacQuery, IcpacVO, IcpacForm, WebTableTreeQuery, WebTableTreeVO, WebTableTreeForm } from './types'

// 本地访问测试环境数据
const serviceParams:any = (import.meta.env.MODE === 'development') ? import.meta.env.VITE_APP_PROXY_BASE_API : undefined;

/**
 * 查询WEB应用列表
 * @param
 * @returns
 */
export function getIcpacWebList(queryParams?: IcpacQuery): AxiosPromise<IcpacVO[]> {
    return request({
        url: "/lowcode/dynamicCreate/queryList/companyApplication/0000",
        method: "post",
        data: queryParams
    }, serviceParams); // 添加 serviceParams 代表从本地代理访问线上地址,否则 访问本地mock地址
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Vue项目,可以使用mock.js来模拟数据请求。引用\[1\]提到,mock.js可以在后端没有提供接口的情况下,自己模拟一个mock接口去请求,并且可以返回你希望得到的随机数据。这对于本地开发和演示项目非常有用。引用\[2\]提到,使用mock.js可以完全本地化实现数据,方便前端人员定义接口数据,并且可以配合后台人员进行开发。在Vue项目,可以通过引入mock.js并定义mock接口来模拟数据请求。例如,可以在一个mock文件夹创建一个mock.js文件,然后在该文件定义接口和返回的数据。在Vue组件,可以通过发送请求来获取mock数据。引用\[3\]给出了一个示例,展示了如何使用mock.js来请求获取.json文件的数据。在该示例,首先引入了mock-request工具和项目的设置文件,然后定义了一个tableData函数来发送请求并获取数据。这样,你就可以在Vue项目使用mock.js来模拟数据请求了。 #### 引用[.reference_title] - *1* [【Vue】使用mock模拟数据](https://blog.csdn.net/ZHANGYANG_1109/article/details/124547442)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [vue本地模拟服务器请求mock数据](https://blog.csdn.net/liyoro/article/details/119616107)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值