想使用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 "htmlcode">
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一些查询参数,并在使用传入的参数取对应数据。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“基于Koa(nodejs框架)对json文件进行增删改查的示例代码”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
2025年11月08日
2025年11月08日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]