、利用Mongoose查询MongoDB

通过mongoose插件可以简捷地从mondodb中获取数据,首先安装mongoose:

  1. cnpm install mongoose --save  

使用mongoose需要一个模式Schema,它用于定义你从mongodb中查询的每个文档条目的内容,然后通过mongoose.model()生成一个模板model,模板像一个架子,将数据库取到的每个条目中的内容按架子的结构填充,这样就形成了一个便于操作、结构条理的数据对象。通过这个对象就可以访问模板的相关属性,甚至为其定义函数方法。

例如mongodb中的条目如图:

针对其定义Schema,生成并导出商品模板goods:

  1. //服务端server/modules/goods.js文件  
  2. const mongoose=require('mongoose');  
  3. let Schema=mongoose.Schema;  
  4.     
  5. let productSchema=new Schema({  
  6.   "productId":String,  
  7.   "productName":String,  
  8.   "salePrice":Number,  
  9.   "productImage":String  
  10. });  
  11. //导出模板goods  
  12. module.exports=mongoose.model('goods',productSchema);  

注意:Schema中字段的名称要与数据库中一致,否则会因为字段不匹配而造成无法插入数据库。例如我在数据库中是productImage,而schema中是productImg,导致插入时丢失字段。

然后通过goods模板执行数据库查询操作,如果有错返回err,否则返回查询结果doc:

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

2、nodeJS服务端查询数据库并返回结果

1、通过express框架进行数据库连接:

  1. //服务端server/routes/goods.js文件  
  2. //包含相关模块  
  3. const express=require('express');  
  4. const router=express.Router();  
  5. const mongoose=require('mongoose');  
  6. const goods=require('../modules/goods')  
  7.     
  8. //连接本地mongodb数据库的mall集合  
  9. mongoose.connect('mongodb://localhost:27017/mall');  
  10. mongoose.connection.on('connected',()=>{  
  11.   console.log("mongoDB连接成功");  
  12. });  
  13. mongoose.connection.on('erroe',()=>{  
  14.   console.log("mongoDB连接出错");  
  15. });  
  16. mongoose.connection.on('disconnected',()=>{  
  17.   console.log("mongoDB断开连接");  
  18. });  

2、对来自前端的get请求进行响应:进行数据库查询并将结果放在result.list中,在加上status、msg,以json形式返回res。

  1. router.get('/',(req,res,next)=>{  
  2.   //利用goods模板调用mongooseAPI进行数据库查询  
  3.   goods.find({},(err,doc)=>{  
  4.     "use strict";  
  5.     if (err){  
  6.       res.json({  
  7.         status:1,  
  8.         msg:err.message  
  9.       })  
  10.     }else {  
  11.       res.json({//利用res将数据返回给get请求  
  12.         status:0,  
  13.         msg:'',  
  14.         result:{  
  15.           count:doc.length,  
  16.           list:doc  
  17.         }  
  18.       })  
  19.     }  
  20.   })  
  21. });  

最后记得暴露路由router

  1. module.exports = router;  

注:接收请求参数req一般有三种方式,req.query多用于get请求发送来的数据,get请求将数据以?加在请求路径的尾部,用req.query.keyname可以获取到其中的数据。

req.body用于接收post请求,post请求将数据放在request正文中,因此req.body.keyname可以得到其请求数据。

req.params的参数包含在路径当中,例如请求路径为http://localhost:3000/test/myparam,服务端定义其中的参数为

  1. router.get('/testparams/:param', function (req, res) {  
  2.     console.log('参数为: ' + req.params.param);  
  3. })  

则控制台输出  参数为:myparam

3、跨域请求数据

由于本地vue运行在localhost:8080,而nodejs在localhost:3000,若要在vue中利用axios实现数据请求,则需要执行跨域代理操作。在vue中的config/index.js文件的dev中配置一个转发代理,当请求"/goods"时,转发到localhost:3000下的/goods:

当get请求到达localhost:3000端时,nodeJS文件中的app.js对请求路径进行解析,使用app.use()将/goods定位到routes/goods.js文件,在该文件中执行第二步查询数据库并返回结果:

  1. var goods=require('./routes/goods');  
  2. app.use('/goods',goods);  

4、vue进行数据请求并渲染到页面

在views/GoodsList.vue文件中利用axios对数据进行请求,定义getGoodsList()方法并在挂载后调用:

  1.   mounted:function (){  
  2.     this.getGoodsList();  
  3.   },  
  4.   methods:{  
  5.     getGoodsList(){  
  6.       axios.get("/goods").then(response =>{  
  7.         let res=response.data;  
  8.         if(res.status==0){  
  9.           this.goodsList=res.result.list;  
  10.         }else{  
  11.           console.log("从服务器请求数据失败!");  
  12.         }  
  13.       })  
  14.     },  

代表正常,并且将数据放在了result.list中,在页面中对list数组进行遍历即可将数据渲染到页面:

注意在遍历每个数据对象时,其键名要与在mongoDB中的定义一致,如item.salePrice可以访问到条目的价格

  1.                                 <li v-for="(item,index) in goodsList">  
  2.                                     <div class="pic">  
  3.                                         <a href="#"><img v-lazy="`static/${item.productImage}`" alt=""></a>  
  4.                                     </div>  
  5.                                     <div class="main">  
  6.                                         <div class="name">{{item.productName}}</div>  
  7.                                         <div class="price">{{item.salePrice}}</div>  
  8.                                         <div class="btn-area">  
  9.                                             <a href="javascript:;" class="btn btn--m">加入购物车</a>  
  10.                                         </div>  
  11.                                     </div>  
  12.                                 </li>      

启动mongoDB、nodeJS服务端、运行vue-cli框架后即可在localhost:8080内看到结果如图:

Vue nodejs商城项目- 前后端数据传递的更多相关文章

  1. Vue nodejs商城项目-搭建express框架环境

    1.express-project 搭建express框架环境 安装express generator生成器 通过生成器自动创建项目 配置分析 安装 cnpm i -g express-generat ...

  2. Vue nodejs商城项目-商品列表价格过滤和加入购物车功能

    一.价格过滤功能 GoodsList.vue >>点击价格区间时发送请求 methods:{     getGoodsList(flag){         var param = {   ...

  3. Vue nodejs商城项目-商品的分页、排序、筛选

    .分页 ,要查第3页的数据,则跳过2*8条数据,然后返回8条数据. 在实现滚动加载时,页面刚一加载完成并不需要请求所有数据,当用户下拉到页面底部时,再去请求数据并拼接到商品数据列表中. 通过vue-i ...

  4. Vue nodejs商城项目-登录模块

    一.登录功能 后端server/routes/users.js var User = require('./../models/users.js');   // 二级路由 // 登录接口 router ...

  5. Vue nodejs商城项目-商品列表页面组件

    data(){        return {            goodsList:[], // 商品列表            priceFilter:[ // 价格区间数组          ...

  6. Vue nodejs商城项目-项目概述

    项目概况 用vue2.0 +node.js +MongonDB 做了一个商城系统 技术选型 Vue2.0+node.js+express+MongoDB+axios+vuex 构建工具 Webpack ...

  7. vue-resource的使用,前后端数据交互

    vue-resource的使用,前后端数据交互 1:导入vue与vue-resource的js js下载:   https://pan.baidu.com/s/1fs5QaNwcl2AMEyp_kUg ...

  8. 对GraphQL-BFF:微服务背景下的前后端数据交互方案的研究-------引用

    随着多终端.多平台.多业务形态.多技术选型等各方面的发展,前后端的数据交互,日益复杂. 同一份数据,可能以多种不同的形态和结构,在多种场景下被消费. 在理想情况下,这些复杂性可以全部由后端承担.前端只 ...

  9. Vue 应用 nginx 配置 前后端不分离模式

    一.先在官网下载nginx 软件,解压后放在软件盘中如D盘 将nginx 文件夹拖到编译器中,打开conf 文件夹中的 nginx.conf 文件,找到其中的server {} 配置项,默认35 行. ...

随机推荐

  1. WPF 窗体在Alt+Tab中隐藏

    问题: 近段时间由于项目上的需求,需要在WPF中使用COM组件,并且由于软件界面设计等等原因,需要将部分控件显示在COM组件之上,由于WindowsFormsHost的一些原因,导致继承在WPF中的W ...

  2. win7 docker的受难记——exit status 255的终极解决

    一 我真的认识到我有很多坏习惯,而这次坏就坏在我老是用Docker Quickstart Terminal,而不直接用cmd. 毕竟Docker Quickstart Terminal看属性就是cmd ...

  3. hibernate事务管理 (jdbc jta)

    hibernate的两种事务管理jdbc 和jta方式.下边说说两者的区别一.说明一下jdbc和jta方式事务管理的区别:JDBC事务由Connnection管理,也就是说,事务管理实际上是在JDBC ...

  4. Cocos2d-js 开发记录:声音播放

    声音播放可以使用cc.audioEngine,需要播放的文件在resource.js中进行添加如: button_press_mp3: "res/audio/press.mp3", ...

  5. centos-7.2 node.js免编译安装

    cd /usr/local/ wget https://npm.taobao.org/mirrors/node/v8.9.3/node-v8.9.3-linux-x64.tar.gz tar -zxv ...

  6. 函数进阶3 —— 生成器、yield from

    今天我们在进一步了解一下,生成器. ①: def func(): print('这是函数func') return '函数func' func() 结果是 这是函数func ②: def func1( ...

  7. js变量定义提升、this指针指向、运算符优先级、原型、继承、全局变量污染、对象属性及原型属性优先级

    原文出自:http://www.cnblogs.com/xxcanghai/p/5189353.html作者:小小沧海 题目如下: function Foo() { getName = functio ...

  8. js中实现多态

    最近读到一本书<JavaScript设计模式与开发实践>上,讲到js的多态,我在JavaScript高级程序编程里貌似都没有见过关于这个的详细讲解,所以想问问大家有没有什么推荐的文章或者博 ...

  9. CentOS安装QQ2012

    QQ想必大家都会用,在windows系统下一般都是使用客户端软件,但是在linxu系统下就没有想windows那样的客户端了.下面就次啊用wine在CentOS中安装腾讯QQ2012.

  10. android的MVP模式

    MVP简介 相信大家对MVC都是比较熟悉了:M-Model-模型.V-View-视图.C-Controller-控制器,MVP作为MVC的演化版本,那么类似的MVP所对应的意义:M-Model-模型. ...