這篇文章主要為大家展示了“nodejs框架如何對json文件進(jìn)行增刪改查”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“nodejs框架如何對json文件進(jìn)行增刪改查”這篇文章吧。

想使用nodejs(koa)搭建一個完整的前后端,完成數(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請求傳來的數(shù)據(jù),id是用來查找之前有的數(shù)據(jù)并進(jìn)行修改,新增數(shù)據(jù)的在前臺應(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文件 對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();//將二進(jìn)制的數(shù)據(jù)轉(zhuǎn)換為字符串
jsonData = JSON.parse(jsonData);//將字符串轉(zhuǎn)換為json對象
// 有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ù)項目id'}) : jsonData.push(params);
}
//因為nodejs的寫入文件只認(rèn)識字符串或者二進(jìn)制數(shù),所以把json對象轉(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對象
// 過濾出所存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有值 => 查詢單個
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對象
// 有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()
})當(dāng)然,上面提供的還沒有支持分頁,想要實現(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ù)取對應(yīng)數(shù)據(jù)。
以上是“nodejs框架如何對json文件進(jìn)行增刪改查”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
網(wǎng)站標(biāo)題:nodejs框架如何對json文件進(jìn)行增刪改查-創(chuàng)新互聯(lián)
標(biāo)題鏈接:http://chinadenli.net/article22/gsgjc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、企業(yè)網(wǎng)站制作、定制開發(fā)、動態(tài)網(wǎng)站、品牌網(wǎng)站設(shè)計、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)