這篇文章主要為大家展示了“nodejs框架如何對(duì)json文件進(jìn)行增刪改查”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“nodejs框架如何對(duì)json文件進(jìn)行增刪改查”這篇文章吧。
想使用nodejs(koa)搭建一個(gè)完整的前后端,完成數(shù)據(jù)的增刪改查,又不想使用數(shù)據(jù)庫(kù),那使用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.新增和修改
新增和修改可以分開(kāi),但是為了省代碼就合并在一起了。
deploy.post('/add-modify', async (ctx) => { // 這里使用的bodyParser來(lái)解析post請(qǐng)求傳來(lái)的數(shù)據(jù),id是用來(lái)查找之前有的數(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值=>修改 無(wú)id值=>新增 if (id) { jsonData.splice(jsonData.findIndex(item => item.id === id), 1, params) } else { // 有重復(fù) => 返回-1 無(wú)重復(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的寫(xiě)入文件只認(rèn)識(shí)字符串或者二進(jìn)制數(shù),所以把json對(duì)象轉(zhuǎn)換成字符串重新寫(xiě)入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ì)象 // 過(guò)濾出所存item的id和前端傳來(lái)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.查詢(xún)
deploy.get('/find', async (ctx) => { // 兩種查詢(xún)方式 1.id為空 => 查詢(xún)?nèi)?nbsp;2.id有值 => 查詢(xún)單個(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: '查詢(xún)失敗' + 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è) 無(wú)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)然,上面提供的還沒(méi)有支持分頁(yè),想要實(shí)現(xiàn)分頁(yè),需求改變json格式,如下:
{ "data": [{"id": 1, "name": "唐僧"}, {"id": 2, "name": "孫悟空"}, {"id": 3, "name": "豬八戒"}, {"id": 4, "name": "沙和尚"}], "currentPage": 1, "pageSize": 4, "pageNum": 1, "total": 4 }
新增page一些查詢(xún)參數(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è)資訊頻道!
網(wǎng)站標(biāo)題:nodejs框架如何對(duì)json文件進(jìn)行增刪改查-創(chuàng)新互聯(lián)
標(biāo)題鏈接:http://www.chinadenli.net/article22/gsgjc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、企業(yè)網(wǎng)站制作、定制開(kāi)發(fā)、動(dòng)態(tài)網(wǎng)站、品牌網(wǎng)站設(shè)計(jì)、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容