vue3+ts+mock實(shí)現(xiàn)增刪改查json文件的示例代碼
1.代碼結(jié)構(gòu)圖:


2.路由
import { createRouter, createWebHashHistory } from "vue-router";
import Home from "@/pages/home/index.vue";
import AppDetail from "@/pages/app-detail/index.vue";
import PageDetail from "@/pages/page-detail/index.vue";
const routes = [
{
path: `/`,
component: Home,
},
{
path: `/app/:id`,
name: 'app',
component: AppDetail,
},
{
path: `/page/:id`,
name: 'page',
component: PageDetail,
},
];
const router = createRouter({
history: createWebHashHistory(),
routes: routes,
});
export default router;3.在api文件夾中創(chuàng)建index.ts文件

import { request } from "@/utils"
export const queryApp = () => request("/web_bp_api/app/list");
export const addApp = (newData: any) => request('/web_bp_api/app/add', newData);
export const updateApp = (id: number | string, updatedData: any) => request(`/web_bp_api/app/update`, { id, updatedData });
export const deleteApp = (id: number | string) => request(`/web_bp_api/app/delete`, { id });
export const queryPage = () => request("/web_bp_api/page/list");
export const addPage = (newPageData: any) => request('/web_bp_api/page/add', newPageData);
export const updatePage = (pageId: string | number, updatedPageData: any) => request(`/web_bp_api/page/update`, { pageId, updatedPageData });
export const deletePage = (pageId: string | number) => request(`/web_bp_api/page/delete`, { pageId });
export const queryModule = () => request("/web_bp_api/module/list");
export const addModule = (newModuleData: any) => request('/web_bp_api/module/add', newModuleData);
export const updateModule = (moduleId: string | number, updatedModuleData: any) => request(`/web_bp_api/module/update`, { moduleId, updatedModuleData });
export const deleteModule = (moduleId: string | number) => request(`/web_bp_api/module/delete`, { moduleId });4.mock

import { responseSuccessFormat, responseErrorFormat } from "./utils";
import * as fs from 'fs';
import * as path from 'path';
// 加載初始數(shù)據(jù)
const appData = JSON.parse(fs.readFileSync(path.resolve('./mock/data/app.json'), 'utf8'));
const pageData = JSON.parse(fs.readFileSync(path.resolve('./mock/data/page.json'), 'utf8'));
const moduleData = JSON.parse(fs.readFileSync(path.resolve('./mock/data/module.json'), 'utf8'));
// 在內(nèi)存中模擬數(shù)據(jù)庫(kù)
const mockDatabase = {
app: appData,
page: pageData,
module: moduleData
};
// 模擬的API路由處理函數(shù)
export default {
// 列出應(yīng)用(使用GET)
"POST /web_bp_api/app/list": responseSuccessFormat(mockDatabase.app),
// 新增應(yīng)用(使用POST)
"POST /web_bp_api/app/add": (req: any) => {
console.log(req.body)
const model = mockDatabase.app.reduce((prev: { id: number; }, curr: { id: number; }) => {
return prev.id > curr.id ? prev : curr
})
console.log(model.id)
const newData = req.body; // 假設(shè)請(qǐng)求體中包含新數(shù)據(jù)
newData.id = parseInt(model.id) + 1;
newData.createTime = new Date().toLocaleString();
newData.updateTime = "";
mockDatabase.app.push(newData); // 模擬添加到數(shù)組中
fs.writeFileSync(path.resolve('./mock/data/app.json'), JSON.stringify(mockDatabase.app, null, 2), 'utf8');
return responseSuccessFormat(newData); // 返回新添加的數(shù)據(jù)作為示例
},
// 刪除應(yīng)用(使用DELETE,需要ID)
"POST /web_bp_api/app/delete": (req: any) => {
console.log(req.body)
const id = req.body.id;
// 假設(shè)ID是索引(在真實(shí)應(yīng)用中,您可能需要更復(fù)雜的邏輯來(lái)找到對(duì)象)
const index = mockDatabase.app.findIndex((item: { id: number; }) => item.id === parseInt(id));
if (index !== -1) {
mockDatabase.app.splice(index, 1); // 從數(shù)組中刪除
fs.writeFileSync(path.resolve('./mock/data/app.json'), JSON.stringify(mockDatabase.app, null, 2), 'utf8');
return responseSuccessFormat({ deletedId: id });
} else {
return { status: 404, message: '未找到指定ID的應(yīng)用' };
}
},
// 更新應(yīng)用(使用PUT,需要ID)
"POST /web_bp_api/app/update": (req: any) => {
console.log(req.body)
const id = req.body.id;
const newData = req.body.updatedData;
newData.updateTime = new Date().toLocaleString();
const index = mockDatabase.app.findIndex((item: { id: number; }) => item.id === parseInt(id));
if (index !== -1) {
mockDatabase.app[index] = { ...mockDatabase.app[index], ...newData };
// 現(xiàn)在,您可能需要將更新后的數(shù)據(jù)寫回文件
fs.writeFileSync(path.resolve('./mock/data/app.json'), JSON.stringify(mockDatabase.app, null, 2), 'utf8');
return responseSuccessFormat(mockDatabase.app[index]);
} else {
return { status: 404, message: '未找到指定ID的應(yīng)用' };
}
},
"POST /web_bp_api/page/list": responseSuccessFormat(mockDatabase.page),
"POST /web_bp_api/page/add": (req: any) => {
const newData = req.body; // 假設(shè)請(qǐng)求體中包含新數(shù)據(jù)
mockDatabase.page.push(newData); // 模擬添加到數(shù)組中
// 現(xiàn)在,您可能需要將更新后的數(shù)據(jù)寫回文件
fs.writeFileSync(path.resolve('./mock/data/page.json'), JSON.stringify(mockDatabase.page, null, 2), 'utf8');
return responseSuccessFormat(newData); // 返回新添加的數(shù)據(jù)作為示例
},
"POST /web_bp_api/page/delete": (req: any) => {
const { id } = req.params;
// 假設(shè)ID是索引(在真實(shí)應(yīng)用中,您可能需要更復(fù)雜的邏輯來(lái)找到對(duì)象)
const index = mockDatabase.page.findIndex((item: { id: number; }) => item.id === parseInt(id));
if (index !== -1) {
mockDatabase.page.splice(index, 1); // 從數(shù)組中刪除
return responseSuccessFormat({ deletedId: id });
} else {
return { status: 404, message: '未找到指定ID的應(yīng)用' };
}
},
"POST /web_bp_api/page/update": (req: any) => {
const { id } = req.params;
const newData = req.body;
const index = mockDatabase.page.findIndex((item: { id: number; }) => item.id === parseInt(id));
if (index !== -1) {
mockDatabase.page[index] = { ...mockDatabase.page[index], ...newData };
return responseSuccessFormat(mockDatabase.page[index]);
} else {
return { status: 404, message: '未找到指定ID的應(yīng)用' };
}
},
"POST /web_bp_api/module/list": responseSuccessFormat(mockDatabase.module),
"POST /web_bp_api/module/add": (req: any) => {
const newData = req.body; // 假設(shè)請(qǐng)求體中包含新數(shù)據(jù)
mockDatabase.module.push(newData); // 模擬添加到數(shù)組中
return responseSuccessFormat(newData); // 返回新添加的數(shù)據(jù)作為示例
},
"POST /web_bp_api/module/delete": (req: any) => {
const { id } = req.params;
const index = mockDatabase.module.findIndex((item: { id: number; }) => item.id === parseInt(id));
if (index !== -1) {
mockDatabase.module.splice(index, 1);
return responseSuccessFormat({ deletedId: id });
} else {
return { status: 404, message: '未找到指定ID的應(yīng)用' };
}
},
"POST /web_bp_api/module/update": (req: any) => {
const { id } = req.params;
const newData = req.body;
const index = mockDatabase.module.findIndex((item: { id: number; }) => item.id === parseInt(id));
if (index !== -1) {
mockDatabase.module[index] = { ...mockDatabase.module[index], ...newData };
return responseSuccessFormat(mockDatabase.module[index]);
} else {
return { status: 404, message: '未找到指定ID的模塊' };
}
},
};app.json文件
[
{
"id": 2,
"name": "租車平臺(tái)56",
"description": "租車業(yè)務(wù)管理后臺(tái)",
"spmid": "a456",
"createTime": "2023-05-09",
"updateTime": "2024/8/25 00:32:43"
},
{
"id": 3,
"name": "埋點(diǎn)管理",
"description": "埋點(diǎn)申請(qǐng)、埋點(diǎn)數(shù)據(jù)報(bào)表查看",
"spmid": "a789",
"createTime": "2023-05-09",
"updateTime": "2023-05-09"
}
]到此這篇關(guān)于vue3+ts+mock實(shí)現(xiàn)增刪改查json文件的示例代碼的文章就介紹到這了,更多相關(guān)vue3 mock增刪改查json內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue.js實(shí)現(xiàn)開(kāi)關(guān)(switch)組件實(shí)例代碼
這篇文章介紹了vue.js實(shí)現(xiàn)開(kāi)關(guān)(switch)組件的實(shí)例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06
Vue使用echarts散點(diǎn)圖在區(qū)域內(nèi)標(biāo)點(diǎn)
這篇文章主要為大家詳細(xì)介紹了Vue使用echarts散點(diǎn)圖在區(qū)域內(nèi)標(biāo)點(diǎn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
rollup3.x+vue2打包組件的實(shí)現(xiàn)
本文主要介紹了rollup3.x+vue2打包組件的實(shí)現(xiàn),詳細(xì)的介紹了打包會(huì)存在的問(wèn)題,包版本的問(wèn)題,babel 轉(zhuǎn)換jsx等問(wèn)題,具有一定的參考價(jià)值,感興趣的可以了解一下2023-03-03
Vue3通過(guò)ref操作Dom元素及hooks的使用方法
這篇文章主要介紹了Vue3通過(guò)ref操作Dom元素及hooks的使用方法,需要的朋友可以參考下2023-01-01
解決vue 子組件修改父組件傳來(lái)的props值報(bào)錯(cuò)問(wèn)題
今天小編就為大家分享一篇解決vue 子組件修改父組件傳來(lái)的props值報(bào)錯(cuò)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11
vue3.0+ts引入詳細(xì)步驟以及語(yǔ)法校驗(yàn)報(bào)錯(cuò)問(wèn)題解決辦法
Vue?3.0是一個(gè)非常流行的JavaScript框架,不僅易于學(xué)習(xí)和使用,而且可以與許多UI框架集成,下面這篇文章主要給大家介紹了關(guān)于vue3.0+ts引入詳細(xì)步驟以及語(yǔ)法校驗(yàn)報(bào)錯(cuò)問(wèn)題的解決辦法,需要的朋友可以參考下2024-01-01
vue自定義switch開(kāi)關(guān)組件,實(shí)現(xiàn)樣式可自行更改
今天小編就為大家分享一篇vue自定義switch開(kāi)關(guān)組件,實(shí)現(xiàn)樣式可自行更改,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11

