node中的数据持久化,node中有没有像vue的响应式对象一样改变对象时直接把对象存到文件中的第三方库

node-little-db

node中的数据持久化方案,适合小型项目和练手项目,如果你学过vue,它可以说是像vue的响应式(reactive)对象一样改变对象时直接把对象存到文件中了。
node-little-db是一个基于 Node.js 的第三方库,用于将对象内容同步到文件中。它的原理非常简单,当您更改对象的内容时,它会自动调用fs.writeFileSync()方法将对象内容写入文件。

文档

English

安装

通过以下命令安装node-little-db

npm i node-little-db

使用

首先,引入node-little-db库:

const db = require('node-little-db')

// 如果你的项目使用了esmodule,也可以像下面这种方式引入
// 阅:https://nodejs.org/api/packages.html#type
// import db from 'node-little-db'

然后,获取一个响应式对象:

const user = db.use('user')

现在,您可以对user对象进行操作了。

设置属性
user.name = 'jack'
user.age = 18
user.hobbies = ['eating', 'sleeping', 'playing Peas']
user.hobbies.push('fish')
user.gender = true
user.address = {
    country: 'China',
    city: 'Beijing',
}
user.address.city = 'Shanghai'

运行后的文件内容示例

{
    "name": "jack",
    "age": 18,
    "hobbies": [
        "eating",
        "sleeping",
        "playing Peas",
        "fish"
    ],
    "address": {
        "country": "China",
        "city": "Shanghai"
    },
    "gender": true
}
读取属性
user.name // 'jack'
user.age // 18
user.hobbies // ['eating', 'sleeping', 'playing Peas']
user.gender // true
user.address // {country: 'China', city: 'Beijing'}
user.address.city // 'Shanghai'

API

db.use([filename, options])

使用指定的文件获取响应式对象,调用该方法后将返回一个代理对象,通过对这个对象进行操作,更改将被同步到文件中。

  • filename(可选):文件名。如果未提供文件名,则会使用默认文件名 db-${Date.now()}.json
  • options(可选):选项对象。
    • options.path:文件存放路径。
    • options.initialData:初始数据,在首次创建文件时使用。
    • options.encoding:文件编码,默认为 utf-8
    • data: 文件数据,如果配置了该选项,每当调用一次db.use方法时会拿该属性的值直接替换掉文件内容(文件中原来有的内容会丢失,因此谨慎使用)。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AI麥爾

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值