中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

nodejs框架如何對json文件進行增刪改查

發布時間:2021-07-22 14:30:00 來源:億速云 閱讀:428 作者:小新 欄目:web開發

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

想使用nodejs(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 ? resolve({code: -1, msg: '新增失敗,有重復項目id'}) : jsonData.push(params);
        }
        //因為nodejs的寫入文件只認識字符串或者二進制數,所以把json對象轉換成字符串重新寫入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();//將二進制的數據轉換為字符串
        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一些查詢參數,并在使用傳入的參數取對應數據。

以上是“nodejs框架如何對json文件進行增刪改查”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

临朐县| 菏泽市| 奉化市| 内黄县| 琼结县| 宁蒗| 延津县| 苏州市| 深州市| 内乡县| 江城| 巴彦淖尔市| 平原县| 铜梁县| 永年县| 朝阳县| 郎溪县| 邹城市| 安塞县| 丘北县| 达州市| 平度市| 蓬莱市| 梅河口市| 宜宾市| 永州市| 兰溪市| 绍兴县| 新竹市| 台前县| 青冈县| 彝良县| 弋阳县| 宣威市| 扶沟县| 新疆| 安阳县| 喀喇沁旗| 宜宾市| 宁城县| 宁陵县|