這篇文章主要為大家展示了“nodejs框架如何對(duì)json文件進(jìn)行增刪改查”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“nodejs框架如何對(duì)json文件進(jìn)行增刪改查”這篇文章吧。
創(chuàng)新互聯(lián)網(wǎng)站建設(shè)提供從項(xiàng)目策劃、軟件開發(fā),軟件安全維護(hù)、網(wǎng)站優(yōu)化(SEO)、網(wǎng)站分析、效果評(píng)估等整套的建站服務(wù),主營(yíng)業(yè)務(wù)為成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè),成都APP應(yīng)用開發(fā)以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。創(chuàng)新互聯(lián)深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!想使用nodejs(koa)搭建一個(gè)完整的前后端,完成數(shù)據(jù)的增刪改查,又不想使用數(shù)據(jù)庫,那使用json文件吧。
代碼準(zhǔn)備
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請(qǐng)求傳來的數(shù)據(jù),id是用來查找之前有的數(shù)據(jù)并進(jìn)行修改,新增數(shù)據(jù)的在前臺(tái)應(yīng)該將id設(shè)置為空 let id = ctx.request.body.id let params = ctx.request.body.params let writeJson = () => { return new Promise((resolve,reject)=>{ // fs模塊讀取json文件 對(duì)fs、path模塊不熟悉的可以去查下官方文檔 fs.readFile(path.join(__dirname, '/data/project.json'),function(err,data){ if(err){ // 報(bào)錯(cuò)返回 resolve({code: -1, msg: '新增失敗' + err}) return console.error(err); } let jsonData = data.toString();//將二進(jìn)制的數(shù)據(jù)轉(zhuǎn)換為字符串 jsonData = JSON.parse(jsonData);//將字符串轉(zhuǎn)換為json對(duì)象 // 有id值=>修改 無id值=>新增 if (id) { jsonData.splice(jsonData.findIndex(item => item.id === id), 1, params) } else { // 有重復(fù) => 返回-1 無重復(fù) => 將params加到j(luò)son數(shù)組末尾 let hasRepeat = jsonData.filter((item) => item.id === params.id); hasRepeat ? resolve({code: -1, msg: '新增失敗,有重復(fù)項(xiàng)目id'}) : jsonData.push(params); } //因?yàn)閚odejs的寫入文件只認(rèn)識(shí)字符串或者二進(jìn)制數(shù),所以把json對(duì)象轉(zhuǎn)換成字符串重新寫入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();//將二進(jìn)制的數(shù)據(jù)轉(zhuǎn)換為字符串 jsonData = JSON.parse(jsonData);//將字符串轉(zhuǎn)換為json對(duì)象 // 過濾出所存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為空 => 查詢?nèi)?nbsp;2.id有值 => 查詢單個(gè) 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();//將二進(jìn)制的數(shù)據(jù)轉(zhuǎn)換為字符串 jsonData = JSON.parse(jsonData);//將字符串轉(zhuǎn)換為json對(duì)象 // 有id值=>單個(gè) 無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() })
當(dāng)然,上面提供的還沒有支持分頁,想要實(shí)現(xiàn)分頁,需求改變json格式,如下:
{ "data": [{"id": 1, "name": "唐僧"}, {"id": 2, "name": "孫悟空"}, {"id": 3, "name": "豬八戒"}, {"id": 4, "name": "沙和尚"}], "currentPage": 1, "pageSize": 4, "pageNum": 1, "total": 4 }
新增page一些查詢參數(shù),并在使用傳入的參數(shù)取對(duì)應(yīng)數(shù)據(jù)。
以上是“nodejs框架如何對(duì)json文件進(jìn)行增刪改查”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!