时间:2021-05-26
本文实例讲述了Vue+Node服务器查询Mongo数据库及页面数据传递操作。分享给大家供大家参考,具体如下:
1、利用Mongoose查询MongoDB
通过mongoose依赖可以简捷地操作mondodb数据库,首先安装mongoose:
cnpm install mongoose --save使用mongoose需要一个模式Schema,它用于定义你从mongodb中查询的每个文档条目的内容,然后通过mongoose.model()生成一个模板model,模板像一个架子,将数据库取到的每个条目中的内容按架子的结构填充,这样就形成了一个便于操作、结构条理的数据对象。通过这个对象就可以访问模板的相关属性,甚至为其定义函数方法。
例如mongodb中的数据库mall中的商品条目如图:
(PHP Storm中有简单的mongo可视化插件。通过搜索mongo plugin安装该插件,之后在phpstorm主菜单的view/Tool Windows中找到mongo explore开启mongo侧边栏工具,并连接到mongo数据库后就能可视化查看其中数据)
针对其定义Schema,生成并导出商品模板goods:
//在服务端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});//导出模板goodsmodule.exports=mongoose.model('goods',productSchema);注意:Schema中字段的名称要与数据库中一致,否则会因为字段不匹配而造成无法操作数据库。例如我在数据库中是productImage,而schema中是productImg,导致插入时丢失字段。
然后通过goods模板执行数据库查询操作,如果有错返回err,否则返回查询结果doc:
goods.find({},(err,doc)=>{callback()});2、Node服务端查询数据库并返回结果
①、通过Express框架进行数据库连接:
//服务端server/routes/goods.js文件//引入相关模块const express=require('express');const router=express.Router();const mongoose=require('mongoose');const goods=require('../modules/goods') //引入goods模板//连接本地mongodb数据库的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请求进行响应:查询数据库mall集合并将结果放在result.list中,再加上status、msg,以json形式返回res。
router.get('/',(req,res,next)=>{ //利用goods模板调用mongooseAPI进行数据库查询 goods.find({},(err,doc)=>{ //查询的回调函数 "use strict"; if (err){ res.json({ status:1, msg:err.message }) }else { res.json({//利用res将数据返回给get请求 status:0, msg:'', result:{ count:doc.length, list:doc } }) } })});最后记得暴露路由router
module.exports = router;注:接收请求中的参数一般有三种方式,
3、跨域请求数据
由于本地Vue运行在localhost:8080,而Node在localhost:3000,若要在vue中利用axios实现数据请求,则需要执行跨域代理操作。在vue中的config/index.js文件的dev中配置一个转发代理,当请求"/goods"时,转发到localhost:3000下的/goods:
Node服务器对get请求的解析过程:当请求到达localhost:3000端时,Node服务器的app.js文件对请求路径进行解析,通过app.use()将/goods定位到routes/goods.js文件,在该文件中查询数据库的操作并返回结果:
var goods=require('./routes/goods'); //包含文件routes/goods.jsapp.use('/goods',goods); //将访问路径定位到文件4、vue进行数据请求并渲染到页面
在views/GoodsList.vue文件中利用axios对数据进行请求,定义getGoodsList()方法并在挂载后调用:
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("从服务器请求数据失败!"); } }) },通过axios的get请求/goods,由于上面做了跨域代理,可以向Node服务端发送请求,在回调函数中,response的data是响应返回的实际内容,我们在服务端定义了返回状态status,为0代表正常,并且将数据放在了result.list中,在页面中对list数组进行遍历即可将数据渲染到页面:
注意在遍历每个数据对象时,其键名要与在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服务端、运行vue-cli框架后即可在localhost:8080内看到结果如图:
希望本文所述对大家node.js程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了PHP实现PDO的mysql数据库操作类。分享给大家供大家参考。具体分析如下:dbconfig类负责配置数据库访问信息,包括:服务器地址、端口、数
一、概念:①数据库同步(主从同步---主数据库写的同时往从服务器写数据)②数据库同步(主主同步---两台数据库服务器互相写数据)二、举例数据库服务器(A)主数据
摘要:基于web的动态网页设计必会涉及到页面间的数据传递,文章探讨了asp设计中常用的web页面间的数据传递方式,分析各种数据传递方式的使用方法、使用场合及优缺
一、PHP连接数据库及基本操作MySQL采用的是'客户机/服务器'架构。使用PHP安装的MySQL扩展函数,和直接使用客户端软件区访问MySQL数据库服务器,原
一、概念:①数据库同步(主从同步---主数据库写的同时往从服务器写数据)②数据库同步(主主同步---两台数据库服务器互相写数据)二、举例主主数据库同步服务器配置