node.js使用mongoose操作數(shù)據(jù)庫(kù)實(shí)現(xiàn)購(gòu)物車的增、刪、改、查功能示例
本文實(shí)例講述了node.js使用mongoose操作數(shù)據(jù)庫(kù)實(shí)現(xiàn)購(gòu)物車的增、刪、改、查功能。分享給大家供大家參考,具體如下:
1、數(shù)據(jù)庫(kù)操作語(yǔ)句
Mongoose通過(guò)model實(shí)現(xiàn)對(duì)每個(gè)集合的操作,在使用前需要先定義model:goods。
①、增加數(shù)據(jù):從集合中查詢一條記錄,并返回doc,對(duì)doc操作之后通過(guò)save()保存到集合
goods.findOne({productId},(err,goodsDoc)=>{ goodsDoc.productNum=1; goodsDoc.save(err,doc); });
②、刪除數(shù)據(jù):
model.remove(conditions,callback(){})
③、修改數(shù)據(jù):
model.update(conditions,updates,callback(){})
④、查詢數(shù)據(jù):
model.find(conditions,callback(){})
2、添加購(gòu)物車
在mongodb中新建用戶user集合,user中有cartList數(shù)組,用戶點(diǎn)擊添加購(gòu)物車時(shí)在前端發(fā)出post請(qǐng)求包括用戶、商品的id。然后在后端查詢到對(duì)應(yīng)的用戶,將其cartList中的商品id進(jìn)行比對(duì),如果在其中,則把商品數(shù)量+1,否則從商品集合中查詢商品信息,插入到cartList數(shù)組中。
前端添加購(gòu)物車請(qǐng)求:
addCart(productId){//加入購(gòu)物車 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'); //連接數(shù)據(jù)庫(kù) mongoose.connect('mongodb://localhost:27017/mall'); mongoose.connection.on('connected',()=>{ console.log("mongoDB連接成功"); }); //處理添加購(gòu)物車請(qǐng)求 router.post('/addCart',(req,res,next)=>{ let userId=req.body.userId; let productId=req.body.productId; let params={ userId }; user.findOne(params,(err,userDoc)=>{//查詢對(duì)應(yīng)用戶信息 if (err){ res.json({ status:1, msg:err.message }); }else{ if(userDoc){ let inCart=false; userDoc.cartList.forEach(function(item){//遍歷cartList比對(duì)商品id if (item.productId==productId){ //若商品在購(gòu)物車內(nèi),數(shù)量增加 inCart=true; item.productNum++; saveDoc(userDoc,res); } }); //所選商品不在購(gòu)物車內(nèi),則從商品列表內(nèi)查找并添加到購(gòu)物車 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數(shù)組內(nèi) console.log(userDoc.cartList); saveDoc(userDoc,res); } }); } } } }) });
利用doc.save將修改后的文檔保存到數(shù)據(jù)庫(kù)
function saveDoc(doc,res) { //保存操作 doc.save((err,doc)=>{ if (err){ res.json({ status:1, msg:err.message }) }else { res.json({ status:0, msg:"添加購(gòu)物車成功", result:'success' }) } }) }
3、從購(gòu)物車刪除數(shù)據(jù)
前端點(diǎn)擊刪除按鈕,調(diào)用deleteCart()發(fā)出post請(qǐng)求,刪除成功重新加載購(gòu)物車列表
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,刪除數(shù)據(jù)庫(kù)中指定條目
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:'數(shù)據(jù)庫(kù)刪除失敗' }) }else{ if(doc){ res.json({ status:0, msg:'購(gòu)物車刪除成功' }) } } }) });
4、修改購(gòu)物車
前端對(duì)不同的按鈕點(diǎn)擊,實(shí)現(xiàn)購(gòu)物車數(shù)量的增、減、選中的改變,調(diào)用editCart(opt,item),然后將修改的數(shù)據(jù)以post發(fā)送
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); } }) }
后端接收要修改的數(shù)據(jù),并對(duì)數(shù)據(jù)庫(kù)進(jìn)行更新:
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:'購(gòu)物車更新成功' }) } }) });
5、查詢購(gòu)物車
前端發(fā)送查詢購(gòu)物車get請(qǐng)求,將結(jié)果數(shù)據(jù)賦予catList,頁(yè)面遍歷cartList渲染數(shù)據(jù)
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); } }) },
后端根據(jù)用戶的cookie,查詢指定的用戶的購(gòu)物車
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:"購(gòu)物車列表查詢失敗" }) } }) });
6、購(gòu)物車的總價(jià)與全選
利用vue的計(jì)算屬性可以實(shí)現(xiàn)屬性的隨時(shí)變化,計(jì)算屬性只有在相關(guān)數(shù)據(jù)發(fā)送改變時(shí)才會(huì)隨之改變,計(jì)算屬性的實(shí)現(xiàn)像函數(shù),但使用類似于一般屬性,例如總價(jià)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; } },
計(jì)算屬性totalPrice由每個(gè)商品單價(jià)*數(shù)量而來(lái),當(dāng)其中有一個(gè)改變時(shí),總價(jià)會(huì)立即改變,顯示在頁(yè)面中。
allSelected由每個(gè)商品是否選中作‘與'運(yùn)算而來(lái),當(dāng)有其中一個(gè)的選中狀態(tài)發(fā)送改變,allSelected也會(huì)改變,并改變購(gòu)物車的全選標(biāo)志。
希望本文所述對(duì)大家node.js程序設(shè)計(jì)有所幫助。
上一篇:Vue移動(dòng)端實(shí)現(xiàn)圖片上傳及超過(guò)1M壓縮上傳
欄 目:JavaScript
下一篇:javascript實(shí)現(xiàn)鼠標(biāo)點(diǎn)擊生成文字特效
本文標(biāo)題:node.js使用mongoose操作數(shù)據(jù)庫(kù)實(shí)現(xiàn)購(gòu)物車的增、刪、改、查功能示例
本文地址:http://mengdiqiu.com.cn/a1/JavaScript/9412.html
您可能感興趣的文章
- 04-02包含javascript舍的詞條
- 01-10使用webpack/gulp構(gòu)建TypeScript項(xiàng)目的方法示例
- 01-10使用JS來(lái)動(dòng)態(tài)操作css的幾種方法
- 01-10在Vue項(xiàng)目中使用Typescript的實(shí)現(xiàn)
- 01-10Vue中使用Lodop插件實(shí)現(xiàn)打印功能的簡(jiǎn)單方法
- 01-10echarts實(shí)現(xiàn)折線圖的拖拽效果
- 01-10JS數(shù)據(jù)類型STRING使用實(shí)例解析
- 01-10node使用request請(qǐng)求的方法
- 01-10angularjs模態(tài)框的使用代碼實(shí)例
- 01-10使用JavaScript計(jì)算前一天和后一天的思路詳解


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02javascript點(diǎn)線,點(diǎn)線的代碼
- 04-02javascript潛力,javascript強(qiáng)大嗎
- 04-02javascript替換字符串,js字符串的替換
- 04-02javascript移出,js 移入移出
- 04-02包含javascript舍的詞條
- 04-02javascript并行,深入理解并行編程 豆瓣
- 04-02javascript匿名,js匿名方法
- 04-02javascript警報(bào),JavaScript警告
- 04-02javascript遮蓋,JavaScript遮蓋PC端頁(yè)面
- 04-02javascript前身,javascript的前身
隨機(jī)閱讀
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10delphi制作wav文件的方法
- 04-02jquery與jsp,用jquery
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子