feat: 数据来源为前端控制,添加本地mock功能但仅做测试

This commit is contained in:
WANGFAN\wangf 2024-11-09 16:03:04 +08:00
parent bf841a9d4c
commit 833036828d
8 changed files with 15 additions and 20 deletions

2
.env
View File

@ -1,5 +1,5 @@
# 生产环境优先级 # 生产环境优先级
# development & production > .env # development & production & test > .env
# title # title
VITE_GLOB_APP_TITLE = SnowAdmin VITE_GLOB_APP_TITLE = SnowAdmin

View File

@ -2,8 +2,9 @@ import axios from "axios";
import router from "@/router"; import router from "@/router";
import { Message } from "@arco-design/web-vue"; import { Message } from "@arco-design/web-vue";
// 是否开启本地mock
const MockFlag = import.meta.env.VITE_APP_OPEN_MOCK === "true"; const MockFlag = import.meta.env.VITE_APP_OPEN_MOCK === "true";
console.log("在这里axios", import.meta.env.VITE_APP_OPEN_MOCK, MockFlag);
// 创建axios实例 // 创建axios实例
const service = axios.create({ const service = axios.create({
baseURL: MockFlag ? "" : "/api" baseURL: MockFlag ? "" : "/api"
@ -21,7 +22,6 @@ service.interceptors.request.use(
// 有token在请求头中携带token // 有token在请求头中携带token
config.headers.Authorization = userInfo.token; config.headers.Authorization = userInfo.token;
} }
console.log("请求拦截", config);
return config; return config;
}, },
function (error: any) { function (error: any) {
@ -33,7 +33,6 @@ service.interceptors.request.use(
// 响应拦截器 // 响应拦截器
service.interceptors.response.use( service.interceptors.response.use(
function (response: any) { function (response: any) {
console.log("响应了", response);
if (response.status != 200) { if (response.status != 200) {
Message.error("服务器异常,请联系管理员"); Message.error("服务器异常,请联系管理员");
return Promise.reject(response.data); return Promise.reject(response.data);

View File

@ -1,9 +1,8 @@
import axios from "@/api"; import axios from "@/api";
export const mockTestAPI = (params: any) => { export const mockTestAPI = () => {
return axios({ return axios({
url: "/mock/test/success", url: "/mock/test/success",
method: "get", method: "get"
params
}); });
}; };

View File

@ -1,12 +1,6 @@
import { createProdMockServer } from "vite-plugin-mock/es/createProdMockServer"; import { createProdMockServer } from "vite-plugin-mock/es/createProdMockServer";
import testModule from "./test/index"; import testModule from "./test/index";
// import userModule from './user/index'
// import tableModule from './person/index'
// import systemModule from './system/index'
// import fileModule from './file/index'
// import cateModule from './cate/index'
// import areaModule from './area/index'
export function setupProdMockServer() { export function setupProdMockServer() {
createProdMockServer([...testModule]); createProdMockServer([...testModule]);

View File

@ -7,7 +7,7 @@ export default [
method: "get", method: "get",
timeout: 500, timeout: 500,
response: () => { response: () => {
return resultSuccess("mock数据成功了"); return resultSuccess("SnowAdmin开源免费Welcome!");
} }
}, },
{ {
@ -15,7 +15,7 @@ export default [
method: "get", method: "get",
timeout: 500, timeout: 500,
response: () => { response: () => {
return resultError(null, "请求数据出错了", 500); return resultError(null, "模拟mock数据出错", 500);
} }
} }
] as MockMethod[]; ] as MockMethod[];

View File

@ -14,10 +14,12 @@ import { mockTestAPI } from "@/api/modules/test/index";
// title // title
const title = import.meta.env.VITE_GLOB_APP_TITLE; const title = import.meta.env.VITE_GLOB_APP_TITLE;
// mock
const onMock = async () => { const onMock = async () => {
console.log("模拟数据"); const MockFlag = import.meta.env.VITE_APP_OPEN_MOCK;
if (MockFlag === "false") return;
let res = await mockTestAPI(); let res = await mockTestAPI();
console.log("数据在这", res); console.log("mock数据成功", res);
}; };
</script> </script>

1
src/vite-env.d.ts vendored
View File

@ -16,3 +16,4 @@ declare module "@codemirror/lang-vue";
declare module "nprogress"; declare module "nprogress";
declare module "@wangeditor/editor-for-vue"; declare module "@wangeditor/editor-for-vue";
declare module "@/directives/modules/custom"; declare module "@/directives/modules/custom";
declare module "mockjs";

View File

@ -9,7 +9,7 @@ import { ArcoResolver } from "unplugin-vue-components/resolvers";
import { vitePluginForArco } from "@arco-plugins/vite-vue"; import { vitePluginForArco } from "@arco-plugins/vite-vue";
import { createSvgIconsPlugin } from "vite-plugin-svg-icons"; import { createSvgIconsPlugin } from "vite-plugin-svg-icons";
import { createHtmlPlugin } from "vite-plugin-html"; import { createHtmlPlugin } from "vite-plugin-html";
import { viteMockServe } from 'vite-plugin-mock' import { viteMockServe } from "vite-plugin-mock";
const themePath = normalizePath(path.normalize("./src/style/global-theme.scss")); const themePath = normalizePath(path.normalize("./src/style/global-theme.scss"));
// https://vitejs.dev/config/ // https://vitejs.dev/config/
@ -78,7 +78,7 @@ export default defineConfig(({ mode }) => {
dts: "src/components.d.ts" dts: "src/components.d.ts"
}), }),
viteMockServe({ viteMockServe({
mockPath: './src/mock/', // 目录位置 mockPath: "./src/mock/", // 目录位置
logger: true, // 是否在控制台显示请求日志 logger: true, // 是否在控制台显示请求日志
supportTs: true, // 是否读取ts文件模块 supportTs: true, // 是否读取ts文件模块
localEnabled: env.VITE_APP_OPEN_MOCK === "true", // 设置是否启用本地mock文件 localEnabled: env.VITE_APP_OPEN_MOCK === "true", // 设置是否启用本地mock文件
@ -87,7 +87,7 @@ export default defineConfig(({ mode }) => {
injectCode: ` injectCode: `
import { setupProdMockServer } from '../src/mock/index'; import { setupProdMockServer } from '../src/mock/index';
setupProdMockServer(); setupProdMockServer();
`, `
}) })
], ],
resolve: { resolve: {