feat: 数据来源为前端控制,添加本地mock功能但仅做测试
This commit is contained in:
parent
bf841a9d4c
commit
833036828d
2
.env
2
.env
@ -1,5 +1,5 @@
|
|||||||
# 生产环境优先级
|
# 生产环境优先级
|
||||||
# development & production > .env
|
# development & production & test > .env
|
||||||
|
|
||||||
# title
|
# title
|
||||||
VITE_GLOB_APP_TITLE = SnowAdmin
|
VITE_GLOB_APP_TITLE = SnowAdmin
|
||||||
|
|||||||
@ -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);
|
||||||
|
|||||||
@ -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
|
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|||||||
@ -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]);
|
||||||
|
|||||||
@ -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[];
|
||||||
|
|||||||
@ -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
1
src/vite-env.d.ts
vendored
@ -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";
|
||||||
|
|||||||
@ -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: {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user