Vue+Node服務(wù)器查詢Mongo數(shù)據(jù)庫及頁面數(shù)據(jù)傳遞的示例分析

這篇文章主要為大家展示了“Vue+Node服務(wù)器查詢Mongo數(shù)據(jù)庫及頁面數(shù)據(jù)傳遞的示例分析”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Vue+Node服務(wù)器查詢Mongo數(shù)據(jù)庫及頁面數(shù)據(jù)傳遞的示例分析”這篇文章吧。

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡(jiǎn)單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名申請(qǐng)、虛擬空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、洛南網(wǎng)站維護(hù)、網(wǎng)站推廣。

具體如下:

1、利用Mongoose查詢MongoDB

通過mongoose依賴可以簡(jiǎn)捷地操作mondodb數(shù)據(jù)庫,首先安裝mongoose:

cnpm install mongoose --save

使用mongoose需要一個(gè)模式Schema,它用于定義你從mongodb中查詢的每個(gè)文檔條目的內(nèi)容,然后通過mongoose.model()生成一個(gè)模板model,模板像一個(gè)架子,將數(shù)據(jù)庫取到的每個(gè)條目中的內(nèi)容按架子的結(jié)構(gòu)填充,這樣就形成了一個(gè)便于操作、結(jié)構(gòu)條理的數(shù)據(jù)對(duì)象。通過這個(gè)對(duì)象就可以訪問模板的相關(guān)屬性,甚至為其定義函數(shù)方法。

例如mongodb中的數(shù)據(jù)庫mall中的商品條目如圖:

Vue+Node服務(wù)器查詢Mongo數(shù)據(jù)庫及頁面數(shù)據(jù)傳遞的示例分析

(PHP Storm中有簡(jiǎn)單的mongo可視化插件。通過搜索mongo plugin安裝該插件,之后在phpstorm主菜單的view/Tool Windows中找到mongo explore開啟mongo側(cè)邊欄工具,并連接到mongo數(shù)據(jù)庫后就能可視化查看其中數(shù)據(jù))

針對(duì)其定義Schema,生成并導(dǎo)出商品模板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
});
//導(dǎo)出模板goods
module.exports=mongoose.model('goods',productSchema);

注意:Schema中字段的名稱要與數(shù)據(jù)庫中一致,否則會(huì)因?yàn)樽侄尾黄ヅ涠斐蔁o法操作數(shù)據(jù)庫。例如我在數(shù)據(jù)庫中是productImage,而schema中是productImg,導(dǎo)致插入時(shí)丟失字段。

然后通過goods模板執(zhí)行數(shù)據(jù)庫查詢操作,如果有錯(cuò)返回err,否則返回查詢結(jié)果doc:

goods.find({},(err,doc)=>{callback()});

2、Node服務(wù)端查詢數(shù)據(jù)庫并返回結(jié)果

①、通過Express框架進(jìn)行數(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連接出錯(cuò)");
});
mongoose.connection.on('disconnected',()=>{
 console.log("mongoDB斷開連接");
});

②、對(duì)來自前端的get請(qǐng)求進(jìn)行響應(yīng):查詢數(shù)據(jù)庫mall集合并將結(jié)果放在result.list中,再加上status、msg,以json形式返回res。

router.get('/',(req,res,next)=>{
 //利用goods模板調(diào)用mongooseAPI進(jìn)行數(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請(qǐng)求
    status:0,
    msg:'',
    result:{
     count:doc.length,
     list:doc
    }
   })
  }
 })
});

最后記得暴露路由router

module.exports = router;

注:接收請(qǐng)求中的參數(shù)一般有三種方式,

  • req.query多用于get請(qǐng)求發(fā)送來的數(shù)據(jù),參數(shù)以?加在請(qǐng)求路徑的尾部,用req.query.keyname可以獲取到其中的數(shù)據(jù)。

  • req.body用于接收post請(qǐng)求,post請(qǐng)求將數(shù)據(jù)放在request正文中,因此req.body.keyname可以得到其請(qǐng)求數(shù)據(jù)。

  • req.params的參數(shù)包含在路徑當(dāng)中,例如請(qǐng)求路徑為http://localhost:3000/test/myparam,在服務(wù)端讀取其中的參數(shù);

router.get('/testparams/:param', function (req, res) {
  console.log('參數(shù)為: ' + req.params.param);  //控制臺(tái)輸出路徑中的參數(shù):myparam
})

3、跨域請(qǐng)求數(shù)據(jù)

由于本地Vue運(yùn)行在localhost:8080,而Node在localhost:3000,若要在vue中利用axios實(shí)現(xiàn)數(shù)據(jù)請(qǐng)求,則需要執(zhí)行跨域代理操作。在vue中的config/index.js文件的dev中配置一個(gè)轉(zhuǎn)發(fā)代理,當(dāng)請(qǐng)求"/goods"時(shí),轉(zhuǎn)發(fā)到localhost:3000下的/goods:

Vue+Node服務(wù)器查詢Mongo數(shù)據(jù)庫及頁面數(shù)據(jù)傳遞的示例分析

Node服務(wù)器對(duì)get請(qǐng)求的解析過程:當(dāng)請(qǐng)求到達(dá)localhost:3000端時(shí),Node服務(wù)器的app.js文件對(duì)請(qǐng)求路徑進(jìn)行解析,通過app.use()將/goods定位到routes/goods.js文件,在該文件中查詢數(shù)據(jù)庫的操作并返回結(jié)果:

var goods=require('./routes/goods');  //包含文件routes/goods.js
app.use('/goods',goods);        //將訪問路徑定位到文件

4、vue進(jìn)行數(shù)據(jù)請(qǐng)求并渲染到頁面

在views/GoodsList.vue文件中利用axios對(duì)數(shù)據(jù)進(jìn)行請(qǐng)求,定義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ù)器請(qǐng)求數(shù)據(jù)失??!");
    }
   })
  },

通過axios的get請(qǐng)求/goods,由于上面做了跨域代理,可以向Node服務(wù)端發(fā)送請(qǐng)求,在回調(diào)函數(shù)中,response的data是響應(yīng)返回的實(shí)際內(nèi)容,我們?cè)诜?wù)端定義了返回狀態(tài)status,為0代表正常,并且將數(shù)據(jù)放在了result.list中,在頁面中對(duì)list數(shù)組進(jìn)行遍歷即可將數(shù)據(jù)渲染到頁面:

注意在遍歷每個(gè)數(shù)據(jù)對(duì)象時(shí),其鍵名要與在mongoDB中的定義一致,如item.salePrice可以訪問到條目的價(jià)格

<li v-for="(item,index) in goodsList">
  <div class="pic">
    <a href="#" rel="external nofollow" ><img v-lazy="`static/${item.productImage}`" ></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">加入購(gòu)物車</a>
    </div>
  </div>
</li>

啟動(dòng)mongoDB、Node服務(wù)端、運(yùn)行vue-cli框架后即可在localhost:8080內(nèi)看到結(jié)果如圖:

Vue+Node服務(wù)器查詢Mongo數(shù)據(jù)庫及頁面數(shù)據(jù)傳遞的示例分析

以上是“Vue+Node服務(wù)器查詢Mongo數(shù)據(jù)庫及頁面數(shù)據(jù)傳遞的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

當(dāng)前題目:Vue+Node服務(wù)器查詢Mongo數(shù)據(jù)庫及頁面數(shù)據(jù)傳遞的示例分析
當(dāng)前網(wǎng)址:http://muchs.cn/article48/pidihp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開發(fā)、網(wǎng)站收錄微信小程序、網(wǎng)站營(yíng)銷、微信公眾號(hào)、ChatGPT

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)