摘要:本文介紹了基于的文件的增刪改查。代碼準備路由增刪改查接口,可添加在下面裝載所有子路由示例唐僧孫悟空豬八戒沙和尚新增和修改新增和修改可以分開,但是為了省代碼就合并在一起了。
想使用nodejs(koa)搭建一個完整的前后端,完成數據的增刪改查,又不想使用數據庫,那使用json文件吧。
本文介紹了基于koa的json文件的增、刪、改、查。
代碼準備
const Koa = require("koa") const bodyParser = require("koa-bodyparser") const Router = require("koa-router") const fs = require("fs") const path = require("path") const app = new Koa() const router = new Router() app.use(bodyParser()) // 路由 const deploy = new Router() // 增刪改查接口,可添加在下面 // 裝載所有子路由 router.use("/deploy", deploy.routes(), deploy.allowedMethods()) app.use(router.routes()).use(router.allowedMethods()) app.listen(3000);
json示例
[ {"id": 1, "name": "唐僧"}, {"id": 2, "name": "孫悟空"}, {"id": 3, "name": "豬八戒"}, {"id": 4, "name": "沙和尚"} ]1.新增和修改
新增和修改可以分開,但是為了省代碼就合并在一起了。
deploy.post("/add-modify", async (ctx) => { // 這里使用的bodyParser來解析post請求傳來的數據,id是用來查找之前有的數據并進行修改,新增數據的在前臺應該將id設置為空 let id = ctx.request.body.id let params = ctx.request.body.params let writeJson = () => { return new Promise((resolve,reject)=>{ // fs模塊讀取json文件 對fs、path模塊不熟悉的可以去查下官方文檔 fs.readFile(path.join(__dirname, "/data/project.json"),function(err,data){ if(err){ // 報錯返回 resolve({code: -1, msg: "新增失敗" + err}) return console.error(err); } let jsonData = data.toString();//將二進制的數據轉換為字符串 jsonData = JSON.parse(jsonData);//將字符串轉換為json對象 // 有id值=>修改 無id值=>新增 if (id) { jsonData.splice(jsonData.findIndex(item => item.id === id), 1, params) } else { // 有重復 => 返回-1 無重復 => 將params加到json數組末尾 let hasRepeat = jsonData.filter((item) => item.id === params.id); hasRepeat ? resolve({code: -1, msg: "新增失敗,有重復項目id"}) : jsonData.push(params); } //因為nodejs的寫入文件只認識字符串或者二進制數,所以把json對象轉換成字符串重新寫入json文件中 let str = JSON.stringify(jsonData); fs.writeFile(path.join(__dirname, "/data/project.json"),str,function(err){ if(err){ resolve({code: -1, msg: "新增失敗" + err}) } resolve({code: 0, msg: "新增成功"}) }) }) }) } // 返回給前端 ctx.body = await writeJson() })2.刪除
刪除,這里使用的get方法
deploy.get("/delete", async (ctx) => { let id = ctx.request.query.id let deleteJson = () => { return new Promise((resolve,reject)=>{ fs.readFile(path.join(__dirname, "/data/project.json"),function(err,data){ if(err){ resolve({code: -1, msg: "刪除失敗" + err}) return console.error(err); } let jsonData = data.toString();//將二進制的數據轉換為字符串 jsonData = JSON.parse(jsonData);//將字符串轉換為json對象 // 過濾出所存item的id和前端傳來id不等的 item ,下面提供了兩種方法filter和splice jsonData = jsonData.filter((item) => item.id !== id); // jsonData.splice(jsonData.findIndex(item => item.id === id), 1) let str = JSON.stringify(jsonData); fs.writeFile(path.join(__dirname, "/data/project.json"),str,function(err){ if(err){ resolve({code: -1, msg: "刪除失敗" + err}) } resolve({code: 0, msg: "刪除成功"}) }) }) }) } ctx.body = await deleteJson() })3.查詢
deploy.get("/find", async (ctx) => { // 兩種查詢方式 1.id為空 => 查詢全部 2.id有值 => 查詢單個 let id = ctx.request.query.id let findJson = () => { return new Promise((resolve,reject)=>{ fs.readFile(path.join(__dirname, "/data/project.json"),function(err,data){ if(err){ resolve({code: -1, msg: "查詢失敗" + err}) return console.error(err); } let jsonData = data.toString();//將二進制的數據轉換為字符串 jsonData = JSON.parse(jsonData);//將字符串轉換為json對象 // 有id值=>單個 無id值=>全部 if (id) { jsonData = jsonData.filter((item) => item.id === id); resolve({code: 0, data: jsonData}) } else { resolve({code: 0, data: jsonData}) } }) }) } ctx.body = await findJson() })
當然,上面提供的還沒有支持分頁,想要實現分頁,需求改變json格式,如下:
{ "data": [{"id": 1, "name": "唐僧"}, {"id": 2, "name": "孫悟空"}, {"id": 3, "name": "豬八戒"}, {"id": 4, "name": "沙和尚"}], "currentPage": 1, "pageSize": 4, "pageNum": 1, "total": 4 }
新增page一些查詢參數,并在使用傳入的參數取對應數據。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/101502.html
摘要:項目地址寫在開頭本文主要分享我如何使用對實現增刪改查操作,感謝社區所有精品文章的幫助,以及的開源項目對我的啟發。我們這個項目是建立一個班級學生管理系統,能夠對學生的姓名及學號進行增刪改查的操作。 項目地址:https://github.com/jrainlau/mongoose_cru... 寫在開頭 本文主要分享我如何使用express+mongoose對mongodb實現增刪改查...
摘要:本周寫實驗,需要提供簡單的后臺接口對數據庫進行增刪改查,以前寫后臺只用過和因為比較容易,用寫的也比較快,所以這次想用實現簡單的增刪改查接口。 本周寫實驗,需要提供簡單的后臺接口對數據庫進行增刪改查,以前寫后臺只用過php和java,因為比較容易,用js寫的也比較快,所以這次想用js實現簡單的增刪改查接口。 初始化 需要工具:nodejs 依賴:express,mysql,body-p...
摘要:一前言因公司需要選用做全文檢索,持久化存儲選用的是,但是希望里面的數據發生改變可以實時同步到上,一開始主要使用的版本,可以搞定這個問題。或者修改中的某一條數據,也會實時同步到中。如何把的主文檔和附件信息都同步到中利用的來實現。 一、前言 因公司需要選用elasticsearch做全文檢索,持久化存儲選用的是mongodb,但是希望mongodb里面的數據發生改變可以實時同步到elast...
閱讀 3298·2021-09-08 09:45
閱讀 1255·2019-08-30 15:53
閱讀 1527·2019-08-30 14:12
閱讀 986·2019-08-29 17:01
閱讀 2574·2019-08-29 15:35
閱讀 398·2019-08-29 13:09
閱讀 1975·2019-08-29 12:32
閱讀 3088·2019-08-26 18:37