前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >nodejs写入json文件_json文件可以删除吗

nodejs写入json文件_json文件可以删除吗

作者头像
全栈程序员站长
发布2022-11-04 11:58:17
2.9K0
发布2022-11-04 11:58:17
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

哈喽!nodejs的文件系统,接触过node的对node的文件系统肯定不会陌生,这两天我就在思考一个问题,我是否可以在本地操作我的本地json文件,这样一个本地的文本数据库就有了,如果是便签之类,记录的软件,我完全可以不用连后台的数据库,我可以自己操作本地的json文件,自己用node写后台,答案是肯定的,下面我们就一起来实现一下吧,对本地json文件的增、删、改、查

##1.增 首先我们先看一下demo的目录结构

这里写图片描述
这里写图片描述

我们看一下person.json的内容

这里写图片描述
这里写图片描述

没毛病,接下来就是见证奇迹的时刻了 下面写nodejs的代码

代码语言:javascript
复制
var fs = require('fs');
var params = { 

"id":5,
"name":"白眉鹰王"
}//在真实的开发中id肯定是随机生成的而且不会重复的,下一篇写如何生成随机切不会重复的随机数,现在就模拟一下假数据
//写入json文件选项
function writeJson(params){ 

//现将json文件读出来
fs.readFile('./mock/person.json',function(err,data){ 

if(err){ 

return console.error(err);
}
var person = data.toString();//将二进制的数据转换为字符串
person = JSON.parse(person);//将字符串转换为json对象
person.data.push(params);//将传来的对象push进数组对象中
person.total = person.data.length;//定义一下总条数,为以后的分页打基础
console.log(person.data);
var str = JSON.stringify(person);//因为nodejs的写入文件只认识字符串或者二进制数,所以把json对象转换成字符串重新写入json文件中
fs.writeFile('./mock/person.json',str,function(err){ 

if(err){ 

console.error(err);
}
console.log('----------新增成功-------------');
})
})
}
writeJson(params)//执行一下;

结果如下

这里写图片描述
这里写图片描述

下面我们来看一下json文件的结果

这里写图片描述
这里写图片描述

看,json文件已经被新增进来了

##2.删

代码语言:javascript
复制
var fs = require('fs');
//删除json文件中的选项
function deleteJson(id){ 

fs.readFile('./mock/person.json',function(err,data){ 

if(err){ 

return console.error(err);
}
var person = data.toString();
person = JSON.parse(person);
//把数据读出来删除
for(var i = 0; i < person.data.length;i++){ 

if(id == person.data[i].id){ 

//console.log(person.data[i])
person.data.splice(i,1);
}
}
console.log(person.data);
person.total = person.data.length;
var str = JSON.stringify(person);
//然后再把数据写进去
fs.writeFile('./mock/person.json',str,function(err){ 

if(err){ 

console.error(err);
}
console.log("----------删除成功------------");
})
})
}
deleteJson(5);//执行一下
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述

第5个就删除了

##3.改

一开始的json文件是这个样子的

这里写图片描述
这里写图片描述

下面上代码

代码语言:javascript
复制
var fs = require('fs');
var params = { 

"name":"孙悟空"
}
function changeJson(id,params){ 

fs.readFile('./mock/person.json',function(err,data){ 

if(err){ 

console.error(err);
}
var person = data.toString();
person = JSON.parse(person);
//把数据读出来,然后进行修改
for(var i = 0; i < person.data.length;i++){ 

if(id == person.data[i].id){ 

console.log('id一样的');
for(var key in params){ 

if(person.data[i][key]){ 

person.data[i][key] = params[key];
}
}
}
}
person.total = person.data.length;
var str = JSON.stringify(person);
//console.log(str);
fs.writeFile('./mock/person.json',str,function(err){ 

if(err){ 

console.error(err);
}
console.log('--------------------修改成功');
console.log(person.data);
})
})
}
changeJson(3,params)//执行一下;

结果如下

这里写图片描述
这里写图片描述

看一下json文件

这里写图片描述
这里写图片描述

修改成功!!!!

##4.查 现在模拟一下分页 先看一下json文件长什么样

这里写图片描述
这里写图片描述

上代码

代码语言:javascript
复制
var fs = require('fs');
//通过传回来的页数,进行分页模拟
function pagination(p,s){ 

//p为页数,比如第一页传0,第二页传1,s为每页多少条数据
fs.readFile('./mock/person.json',function(err,data){ 

if(err){ 

console.error(err);
}
var person = data.toString();
person = JSON.parse(person);
//把数据读出来
//console.log(person.data);
var length = person.data.length;
var pagePerson = person.data.slice(s*p,(p+1)*s);
console.log('------------------------查询成功pagePerson');
console.log(pagePerson);
})
}
pagination(0,6);//查询第一页,每页的数据条数为6条

执行结果为

这里写图片描述
这里写图片描述

下面看一下第二页 执行pagination(1,6); 执行结果为

这里写图片描述
这里写图片描述

以此类推,就实现了模拟分页的效果

##5.总结 ok,一套基本的增删改查就这样写完了,感觉node还是特别强大的,感觉自己又进步了一些,虽然可能有人觉得这样写没有意义,也许吧,但是我觉得很有意义,让我也收获了不少!!!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/182770.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月12日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档