• <abbr id="chdyf"></abbr>
    <ruby id="chdyf"><acronym id="chdyf"><meter id="chdyf"></meter></acronym></ruby>
    <bdo id="chdyf"></bdo>
    <dfn id="chdyf"><menu id="chdyf"></menu></dfn>
    1. <menuitem id="chdyf"></menuitem><strong id="chdyf"><menu id="chdyf"></menu></strong>

      <rt id="chdyf"><menu id="chdyf"></menu></rt>
      成人小说一区二区三区,伊人精品成人久久综合全集观看,久久HEZYO色综合,中文字幕精品人妻熟女,影音先锋成人网站,我要看免费一级毛片,中国女人做爰A片,中文字幕av久久爽Av

      mongoose中save無法獲取回調函數值的解決方法

      2018-7-18    seo達人

      如果您想訂閱本博客內容,每天自動發到您的郵箱中, 請點這里

      mongoose保存數據:

      const save = new Model(data).save()
          
      • 1

      如果成功,則可以獲取到保存在數據庫的值,但是如果保存數據失敗,則會拋出異常,好在save可以傳入一個回調函數,用法如下:

      const save = new Model(data).save((err, result)=>{ if(err){ // 保存失敗執行的操作
          }else { // 保存成功執行的操作
          }
      
      })
          
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8

      我們希望根據結果獲取到不同的值,但是此時save返回的是undefined,因為save中的回調函數是一個異步操作

      解決方法:

      使用try catch:

      try{
          const save = await new Model(data).save();
          // 保存成功執行的操作 return ... }catch(err){
          // 保存失敗執行的操作 return ... }
          
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8

      注意:在async函數中才可以這么使用,因為await只能用在async函數中

      示例:(注冊功能)

      user.model.js

      const mongoose  = require("mongoose"); const port      = process.env.PORT || "8899"; const UserSchema = mongoose.Schema({
          userName: {
              type: String,
              unique: true },
          passWord: String,
          createTime: {
              type: Date, default: Date.now()
          },
          updateTime: {
              type: Date, default: Date.now()
          }
      }, {
          timestamps: {
              createAt: "createTime",
              updateTime: "updateTime" }
      });
      
      module.exports = mongoose.model("USER", UserSchema);
          
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14
      • 15
      • 16
      • 17
      • 18
      • 19
      • 20
      • 21
      • 22
      • 23
      • 24
      • 25

      service.js

      const User = require("./user.model);
      class User{
          async login(user){
                  try{
                      const result = await new User(user).save();
                      // 其他操作,如發送注冊郵件
                      return { success: true }
                  }catch(err){
                      return { success: false, message: "用戶名或密碼錯誤" }
                  }
         }
      }
      moduel.exports = new User();
          
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13

      controller.js

      const server = require("./server); async login(){ // 首先獲取請求中攜帶的用戶信息 const result = await server.login(user);
          if(result.success){ // 注冊成功執行的操作 }else { // 注冊失敗執行的操作 }
      }
      藍藍設計www.wtxcl.cn )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務

      日歷

      鏈接

      個人資料

      藍藍設計的小編 http://www.wtxcl.cn

      存檔

      主站蜘蛛池模板: 亚洲色伦| 多人乱p视频在线免费观看| 3p露脸在线播放| 中文字幕一精品亚洲无线一区| 通榆县| 亚洲瑟瑟瑟| 狠狠色噜噜狠狠狠狠av| 国产尤物极品在线观看| 亚洲精品国产日韩无码AV永久免费网| 强被迫伦姧在线观看无码| 黄色av日韩在线观看| 无码人妻精品一区二区三区蜜臀百度 | 久久久噜噜噜久久中文字幕色伊伊 | 精品无码产区一区二| 国产主播福利精品一区二区| 免费国产一级 片内射老| 亚洲三区四区| 东方AV免费观看久久AV| 乱子伦av无码中文字幕| 中文AV电影网| 日韩无码专区| 在线观看片免费人成视频无码 | 欧美一片二片午夜福利在线快| 国产丝袜在线视频| 亚洲综合社区| 三浦在线| 亚洲综合图区小说专区| 色~性~乱~伦~噜| 精品人妻一区介绍| 成人在线男人天堂av| 精品久久一区| 欧美日韩在线观看视频| 亚洲线精品一区二区三区八戒| 欧美交a欧美精品喷水| 草肥熟老熟妇600部| 熟女AV在线| 欧美日韩国产在线观看免费| 18禁久久| 亚欧在线视频| 国产自产在线视频一区第二页| 亚洲成人天堂网|