Vue+Node服務(wù)器查詢Mongo數(shù)據(jù)庫及頁面數(shù)據(jù)傳遞操作實例分析
本文實例講述了Vue+Node服務(wù)器查詢Mongo數(shù)據(jù)庫及頁面數(shù)據(jù)傳遞操作。分享給大家供大家參考,具體如下:
1、利用Mongoose查詢MongoDB
通過mongoose依賴可以簡捷地操作mondodb數(shù)據(jù)庫,首先安裝mongoose:
cnpm install mongoose --save
使用mongoose需要一個模式Schema,它用于定義你從mongodb中查詢的每個文檔條目的內(nèi)容,然后通過mongoose.model()生成一個模板model,模板像一個架子,將數(shù)據(jù)庫取到的每個條目中的內(nèi)容按架子的結(jié)構(gòu)填充,這樣就形成了一個便于操作、結(jié)構(gòu)條理的數(shù)據(jù)對象。通過這個對象就可以訪問模板的相關(guān)屬性,甚至為其定義函數(shù)方法。
例如mongodb中的數(shù)據(jù)庫mall中的商品條目如圖:
(PHP Storm中有簡單的mongo可視化插件。通過搜索mongo plugin安裝該插件,之后在phpstorm主菜單的view/Tool Windows中找到mongo explore開啟mongo側(cè)邊欄工具,并連接到mongo數(shù)據(jù)庫后就能可視化查看其中數(shù)據(jù))
針對其定義Schema,生成并導出商品模板goods:
//在服務(wù)端server/modules文件夾下新建goods.js文件 const mongoose=require('mongoose'); let Schema=mongoose.Schema; let productSchema=new Schema({ //通過mongoose的Schema定義模板 "productId":String, "productName":String, "salePrice":Number, "productImage":String }); //導出模板goods module.exports=mongoose.model('goods',productSchema);
注意:Schema中字段的名稱要與數(shù)據(jù)庫中一致,否則會因為字段不匹配而造成無法操作數(shù)據(jù)庫。例如我在數(shù)據(jù)庫中是productImage,而schema中是productImg,導致插入時丟失字段。
然后通過goods模板執(zhí)行數(shù)據(jù)庫查詢操作,如果有錯返回err,否則返回查詢結(jié)果doc:
goods.find({},(err,doc)=>{callback()});
2、Node服務(wù)端查詢數(shù)據(jù)庫并返回結(jié)果
①、通過Express框架進行數(shù)據(jù)庫連接:
//服務(wù)端server/routes/goods.js文件 //引入相關(guān)模塊 const express=require('express'); const router=express.Router(); const mongoose=require('mongoose'); const goods=require('../modules/goods') //引入goods模板 //連接本地mongodb數(shù)據(jù)庫的mall集合 mongoose.connect('mongodb://localhost:27017/mall'); mongoose.connection.on('connected',()=>{ console.log("mongoDB連接成功"); }); mongoose.connection.on('erroe',()=>{ console.log("mongoDB連接出錯"); }); mongoose.connection.on('disconnected',()=>{ console.log("mongoDB斷開連接"); });
②、對來自前端的get請求進行響應(yīng):查詢數(shù)據(jù)庫mall集合并將結(jié)果放在result.list中,再加上status、msg,以json形式返回res。
router.get('/',(req,res,next)=>{ //利用goods模板調(diào)用mongooseAPI進行數(shù)據(jù)庫查詢 goods.find({},(err,doc)=>{ //查詢的回調(diào)函數(shù) "use strict"; if (err){ res.json({ status:1, msg:err.message }) }else { res.json({//利用res將數(shù)據(jù)返回給get請求 status:0, msg:'', result:{ count:doc.length, list:doc } }) } }) });
最后記得暴露路由router
module.exports = router;
注:接收請求中的參數(shù)一般有三種方式,
- req.query多用于get請求發(fā)送來的數(shù)據(jù),參數(shù)以?加在請求路徑的尾部,用req.query.keyname可以獲取到其中的數(shù)據(jù)。
- req.body用于接收post請求,post請求將數(shù)據(jù)放在request正文中,因此req.body.keyname可以得到其請求數(shù)據(jù)。
- req.params的參數(shù)包含在路徑當中,例如請求路徑為http://localhost:3000/test/myparam,在服務(wù)端讀取其中的參數(shù);
router.get('/testparams/:param', function (req, res) { console.log('參數(shù)為: ' + req.params.param); //控制臺輸出路徑中的參數(shù):myparam })
3、跨域請求數(shù)據(jù)
由于本地Vue運行在localhost:8080,而Node在localhost:3000,若要在vue中利用axios實現(xiàn)數(shù)據(jù)請求,則需要執(zhí)行跨域代理操作。在vue中的config/index.js文件的dev中配置一個轉(zhuǎn)發(fā)代理,當請求"/goods"時,轉(zhuǎn)發(fā)到localhost:3000下的/goods:
Node服務(wù)器對get請求的解析過程:當請求到達localhost:3000端時,Node服務(wù)器的app.js文件對請求路徑進行解析,通過app.use()將/goods定位到routes/goods.js文件,在該文件中查詢數(shù)據(jù)庫的操作并返回結(jié)果:
var goods=require('./routes/goods'); //包含文件routes/goods.js app.use('/goods',goods); //將訪問路徑定位到文件
4、vue進行數(shù)據(jù)請求并渲染到頁面
在views/GoodsList.vue文件中利用axios對數(shù)據(jù)進行請求,定義getGoodsList()方法并在掛載后調(diào)用:
mounted:function (){ this.getGoodsList(); }, methods:{ getGoodsList(){ axios.get("/goods").then(response =>{ let res=response.data; if(res.status==0){ this.goodsList=res.result.list; }else{ console.log("從服務(wù)器請求數(shù)據(jù)失??!"); } }) },
通過axios的get請求/goods,由于上面做了跨域代理,可以向Node服務(wù)端發(fā)送請求,在回調(diào)函數(shù)中,response的data是響應(yīng)返回的實際內(nèi)容,我們在服務(wù)端定義了返回狀態(tài)status,為0代表正常,并且將數(shù)據(jù)放在了result.list中,在頁面中對list數(shù)組進行遍歷即可將數(shù)據(jù)渲染到頁面:
注意在遍歷每個數(shù)據(jù)對象時,其鍵名要與在mongoDB中的定義一致,如item.salePrice可以訪問到條目的價格
<li v-for="(item,index) in goodsList"> <div class="pic"> <a href="#" rel="external nofollow" ><img v-lazy="`static/${item.productImage}`" alt=""></a> </div> <div class="main"> <div class="name">{{item.productName}}</div> <div class="price">{{item.salePrice}}</div> <div class="btn-area"> <a href="javascript:;" rel="external nofollow" class="btn btn--m">加入購物車</a> </div> </div> </li>
啟動mongoDB、Node服務(wù)端、運行vue-cli框架后即可在localhost:8080內(nèi)看到結(jié)果如圖:
希望本文所述對大家node.js程序設(shè)計有所幫助。
相關(guān)文章
NodeJS創(chuàng)建最簡單的HTTP服務(wù)器
這篇文章主要介紹了NodeJS創(chuàng)建最簡單的HTTP服務(wù)器的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05nodeJS與MySQL實現(xiàn)分頁數(shù)據(jù)以及倒序數(shù)據(jù)
這篇文章主要介紹了nodeJS與MySQL實現(xiàn)分頁數(shù)據(jù)以及倒序數(shù)據(jù),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-06-06Nodejs 發(fā)布自己的npm包并制作成命令行工具的實例講解
今天小編就為大家分享一篇Nodejs 發(fā)布自己的npm包并制作成命令行工具的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05node連接mysql查詢事務(wù)處理的實現(xiàn)
本文主要介紹了node連接mysql查詢事務(wù)處理的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-11-11koa2 數(shù)據(jù)api中間件設(shè)計模型的實現(xiàn)方法
這篇文章主要介紹了koa2 數(shù)據(jù)api中間件設(shè)計模型的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07Nodejs?連接?mysql時報Error:?Cannot?enqueue?Query?after?fa
這篇文章主要介紹了Nodejs?連接?mysql時報Error:?Cannot?enqueue?Query?after?fatal?error錯誤的處理辦法,需要的朋友可以參考下2023-05-05