<thead id="kdfuf"><font id="kdfuf"></font></thead>
<samp id="kdfuf"></samp>
    <nav id="kdfuf"><strong id="kdfuf"></strong></nav>
      中文字幕无码一区二区三区在线,久久精品人人做人人爽,国产一级内射无挡观看,十八禁在线黄色网站,日韩欧美国产另类久久久精品 ,少妇人妻偷人精品一区二区,久久午夜视频,亚洲春色AⅤ无码专区

      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.tuitetiyu.cn )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務

      日歷

      鏈接

      個人資料

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

      存檔

      主站蜘蛛池模板: 国产综合无码一区二区色蜜蜜| 国产精品欧美久久久久天天影视| 成人精品自拍视频免费看| 精品亚洲香蕉一区二区| 亚洲 成人 无码 在线观看| 中文av国语对白| 99精品久久99久久久久| 国产另类TS人妖一区二区| 99国语精品一区二区三区| 国产精品色哟哟| 乱子轮熟睡1区| 国产精品久久久久AV| 国产重口老太和小伙| 国产一区二区三区视频精品| 欧美亚洲另类精品一区二区| 成人精品一区二区秒拍| 免费观看性行为视频的网站| 好爽…又高潮了免费毛片 | 2020天堂在线亚洲精品| 亚洲日本一区二区三区在线| 国产XXXX99真实实拍| 精品一本久久中文字幕| 国产偷国偷亚洲清高4444 | 男女作爱全部免费观爱| 伴郎粗大的内捧猛烈进出视频观看| 人妻精品丝袜一区二区无码av| 99久久精品国产免| 日本在线视频www色| 曲松县| 精品久久久久久中文字幕无码毛片| 国产亚洲精品午夜高清影院| 国产又粗又大成人片在线观看| av无码专区| 人妻丰满熟妇无码区免费| 三级4级全黄60分钟| 一区二区不卡99精品日韩| 人人鲁人人澡免你贯视频| 成人免费日韩亚洲国产| 亚洲伊人五月丁香激情| 国产一级视频在线观看| 黄色成人网站在线观看|