您好,登錄后才能下訂單哦!
本篇文章為大家展示了怎么在node.js中使用mongoose對數據庫進行操作,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
1、數據庫操作語句
Mongoose通過model實現對每個集合的操作,在使用前需要先定義model:goods。
①、增加數據:從集合中查詢一條記錄,并返回doc,對doc操作之后通過save()保存到集合
goods.findOne({productId},(err,goodsDoc)=>{ goodsDoc.productNum=1; goodsDoc.save(err,doc); });
②、刪除數據:
model.remove(conditions,callback(){})
③、修改數據:
model.update(conditions,updates,callback(){})
④、查詢數據:
model.find(conditions,callback(){})
2、添加購物車
在mongodb中新建用戶user集合,user中有cartList數組,用戶點擊添加購物車時在前端發出post請求包括用戶、商品的id。然后在后端查詢到對應的用戶,將其cartList中的商品id進行比對,如果在其中,則把商品數量+1,否則從商品集合中查詢商品信息,插入到cartList數組中。
前端添加購物車請求:
addCart(productId){//加入購物車 axios.post('./users/addCart',{ userId:"100000077", productId:productId }).then((response)=>{ let res=response.data; console.log(res.msg); }); }
后端處理:
var express = require('express'); var router = express.Router(); const mongoose=require('mongoose'); var user=require('../models/userModel'); var goods=require('../models/productModel'); //連接數據庫 mongoose.connect('mongodb://localhost:27017/mall'); mongoose.connection.on('connected',()=>{ console.log("mongoDB連接成功"); }); //處理添加購物車請求 router.post('/addCart',(req,res,next)=>{ let userId=req.body.userId; let productId=req.body.productId; let params={ userId }; user.findOne(params,(err,userDoc)=>{//查詢對應用戶信息 if (err){ res.json({ status:1, msg:err.message }); }else{ if(userDoc){ let inCart=false; userDoc.cartList.forEach(function(item){//遍歷cartList比對商品id if (item.productId==productId){ //若商品在購物車內,數量增加 inCart=true; item.productNum++; saveDoc(userDoc,res); } }); //所選商品不在購物車內,則從商品列表內查找并添加到購物車 if(!inCart){ goods.findOne({productId},(err,goodsDoc)=>{ if(err){ res.json({ status:1, msg:err.message }) }else{ goodsDoc.checked=true; goodsDoc.productNum=1; userDoc.cartList.push(goodsDoc);//將商品插入到用戶cartList數組內 console.log(userDoc.cartList); saveDoc(userDoc,res); } }); } } } }) });
利用doc.save將修改后的文檔保存到數據庫
function saveDoc(doc,res) { //保存操作 doc.save((err,doc)=>{ if (err){ res.json({ status:1, msg:err.message }) }else { res.json({ status:0, msg:"添加購物車成功", result:'success' }) } }) }
3、從購物車刪除數據
前端點擊刪除按鈕,調用deleteCart()發出post請求,刪除成功重新加載購物車列表
deleteCart(){ axios.post('users/deleteCart',{ productId:this.productId }).then((response,err)=>{ let res=response.data; if(res.status===0){ this.getCart(); this.modalShow=false; } }) },
后端獲取到刪除商品的id、用戶的id,刪除數據庫中指定條目
router.post('/deleteCart',(req,res)=>{ "use strict"; let productId=req.body.productId; let userId=req.cookies.userId; user.update({userId:userId},{ $pull:{ cartList:{productId:productId} } },(err,doc)=>{ if(err){ res.json({ status:1, msg:'數據庫刪除失敗' }) }else{ if(doc){ res.json({ status:0, msg:'購物車刪除成功' }) } } }) });
4、修改購物車
前端對不同的按鈕點擊,實現購物車數量的增、減、選中的改變,調用editCart(opt,item),然后將修改的數據以post發送
editCart(flag,item){ if(flag==='check'){ item.checked=!item.checked; }else if(flag==='add'){ item.productNum++; }else if(flag==='sub'){ item.productNum<=0 ? item.productNum=0 : item.productNum++ ; } axios.post('users/editCart',{ productId:item.productId, checked:item.checked, productNum:item.productNum }).then((response,err)=>{ let res=response.data; if(res.status===0){ this.getCart(); }else{ console.log(res.msg); } }) }
后端接收要修改的數據,并對數據庫進行更新:
router.post('/editCart',(req,res)=>{ "use strict"; let productId=req.body.productId; let checked=req.body.checked; let productNum=req.body.productNum; let userId=req.cookies.userId; user.update({userId:userId,'cartList.productId':productId},{ $set:{"cartList.$.checked":checked,"cartList.$.productNum":productNum} },(err,doc)=>{ if(err){ res.json({ status:1, msg:err.message }) }else { res.json({ status:0, msg:'購物車更新成功' }) } }) });
5、查詢購物車
前端發送查詢購物車get請求,將結果數據賦予catList,頁面遍歷cartList渲染數據
getCart(){ axios.get('users/getCart').then((response,err)=>{ let res=response.data; if(res.status===0){ this.cartList=res.result.list; }else{ console.log(res.msg); } }) },
后端根據用戶的cookie,查詢指定的用戶的購物車
router.get('/getCart',(req,res)=>{ "use strict"; user.findOne({userId:req.cookies.userId},(err,doc)=>{ if(doc){ res.json({ status:0, msg:'', result:{ list:doc.cartList } }) }else{ res.json({ status:1, msg:"購物車列表查詢失敗" }) } }) });
6、購物車的總價與全選
利用vue的計算屬性可以實現屬性的隨時變化,計算屬性只有在相關數據發送改變時才會隨之改變,計算屬性的實現像函數,但使用類似于一般屬性,例如總價totalPrice與判斷是否全部選中allSelected:
computed:{ totalPrice(){ let total=0; this.cartList.forEach((item)=>{ if(item.checked) total+=parseFloat(item.salePrice)*parseInt(item.productNum); }); return total; }, allSelected(){ let selected=true; this.cartList.forEach((item)=>{ selected=selected&&item.checked; }); console.log(selected); return selected; } },
上述內容就是怎么在node.js中使用mongoose對數據庫進行操作,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。