Vue nodejs商城项目- 前后端数据传递
、利用Mongoose查询MongoDB
通过mongoose插件可以简捷地从mondodb中获取数据,首先安装mongoose:
- cnpm install mongoose --save
使用mongoose需要一个模式Schema,它用于定义你从mongodb中查询的每个文档条目的内容,然后通过mongoose.model()生成一个模板model,模板像一个架子,将数据库取到的每个条目中的内容按架子的结构填充,这样就形成了一个便于操作、结构条理的数据对象。通过这个对象就可以访问模板的相关属性,甚至为其定义函数方法。
例如mongodb中的条目如图:

针对其定义Schema,生成并导出商品模板goods:
- //服务端server/modules/goods.js文件
- const mongoose=require('mongoose');
- let Schema=mongoose.Schema;
- let productSchema=new Schema({
- "productId":String,
- "productName":String,
- "salePrice":Number,
- "productImage":String
- });
- //导出模板goods
- module.exports=mongoose.model('goods',productSchema);
注意:Schema中字段的名称要与数据库中一致,否则会因为字段不匹配而造成无法插入数据库。例如我在数据库中是productImage,而schema中是productImg,导致插入时丢失字段。
然后通过goods模板执行数据库查询操作,如果有错返回err,否则返回查询结果doc:
- goods.find({},(err,doc)=>{callback()});
2、nodeJS服务端查询数据库并返回结果
1、通过express框架进行数据库连接:
- //服务端server/routes/goods.js文件
- //包含相关模块
- const express=require('express');
- const router=express.Router();
- const mongoose=require('mongoose');
- const goods=require('../modules/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断开连接");
- });
2、对来自前端的get请求进行响应:进行数据库查询并将结果放在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;
注:接收请求参数req一般有三种方式,req.query多用于get请求发送来的数据,get请求将数据以?加在请求路径的尾部,用req.query.keyname可以获取到其中的数据。
req.body用于接收post请求,post请求将数据放在request正文中,因此req.body.keyname可以得到其请求数据。
req.params的参数包含在路径当中,例如请求路径为http://localhost:3000/test/myparam,服务端定义其中的参数为
- router.get('/testparams/:param', function (req, res) {
- console.log('参数为: ' + req.params.param);
- })
则控制台输出 参数为: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文件,在该文件中执行第二步查询数据库并返回结果:
- var goods=require('./routes/goods');
- app.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("从服务器请求数据失败!");
- }
- })
- },
代表正常,并且将数据放在了result.list中,在页面中对list数组进行遍历即可将数据渲染到页面:
注意在遍历每个数据对象时,其键名要与在mongoDB中的定义一致,如item.salePrice可以访问到条目的价格
- <li v-for="(item,index) in goodsList">
- <div class="pic">
- <a href="#"><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:;" class="btn btn--m">加入购物车</a>
- </div>
- </div>
- </li>
启动mongoDB、nodeJS服务端、运行vue-cli框架后即可在localhost:8080内看到结果如图:

Vue nodejs商城项目- 前后端数据传递的更多相关文章
- Vue nodejs商城项目-搭建express框架环境
1.express-project 搭建express框架环境 安装express generator生成器 通过生成器自动创建项目 配置分析 安装 cnpm i -g express-generat ...
- Vue nodejs商城项目-商品列表价格过滤和加入购物车功能
一.价格过滤功能 GoodsList.vue >>点击价格区间时发送请求 methods:{ getGoodsList(flag){ var param = { ...
- Vue nodejs商城项目-商品的分页、排序、筛选
.分页 ,要查第3页的数据,则跳过2*8条数据,然后返回8条数据. 在实现滚动加载时,页面刚一加载完成并不需要请求所有数据,当用户下拉到页面底部时,再去请求数据并拼接到商品数据列表中. 通过vue-i ...
- Vue nodejs商城项目-登录模块
一.登录功能 后端server/routes/users.js var User = require('./../models/users.js'); // 二级路由 // 登录接口 router ...
- Vue nodejs商城项目-商品列表页面组件
data(){ return { goodsList:[], // 商品列表 priceFilter:[ // 价格区间数组 ...
- Vue nodejs商城项目-项目概述
项目概况 用vue2.0 +node.js +MongonDB 做了一个商城系统 技术选型 Vue2.0+node.js+express+MongoDB+axios+vuex 构建工具 Webpack ...
- vue-resource的使用,前后端数据交互
vue-resource的使用,前后端数据交互 1:导入vue与vue-resource的js js下载: https://pan.baidu.com/s/1fs5QaNwcl2AMEyp_kUg ...
- 对GraphQL-BFF:微服务背景下的前后端数据交互方案的研究-------引用
随着多终端.多平台.多业务形态.多技术选型等各方面的发展,前后端的数据交互,日益复杂. 同一份数据,可能以多种不同的形态和结构,在多种场景下被消费. 在理想情况下,这些复杂性可以全部由后端承担.前端只 ...
- Vue 应用 nginx 配置 前后端不分离模式
一.先在官网下载nginx 软件,解压后放在软件盘中如D盘 将nginx 文件夹拖到编译器中,打开conf 文件夹中的 nginx.conf 文件,找到其中的server {} 配置项,默认35 行. ...
随机推荐
- Sql批处理语句
同时写3个批处理,如果前2个批处理没有问题,最后一个有错误那么3个批处理都不会执行需要注意列如: use Materl GO select * from t_icitem GO inset into ...
- npm安装gulp-sass失败处理办法
最近在做一个基于gulp的前端自动化的项目,在github上拉取代码后,按照正常的流程,首先我们要 npm install ,在安装的过程中,一直提示我gulp-sass 安装失败,我用尽了好多办法 ...
- JVM如何加载一个类的过程,双亲委派模型中有哪些方法
1.类加载过程:加载.验证.准备.解析.初始化 加载 在加载阶段,虚拟机主要完成三件事: 1.通过一个类的全限定名来获取定义此类的二进制字节流. 2.将这个字节流所代表的静态存储结构转化为方法 ...
- csharp: ClientScript.RegisterStartupScript int net4.0
//彈出提示 ClientScriptManager cs = Page.ClientScript; StringBuilder sb = new StringBuilder(); sb.Append ...
- 集合的前N个元素
集合的前N个元素:编一个程序,按递增次序生成集合M的最小的N个数,M的定义如下: (1)数1属于M: (2)如果X属于M,则Y=2*x+1和Z=3*x+1也属于M: (3)此外 ...
- 关于asp.net网站中web.config的配置
1.Session生命周期配置 2.连接默认错误页 实例说明:在一些网站中,当网络地址发生错误时,通常会自动跳转到一个页面,并在该页面显示错误信息,此功能也可以通过配置web.config文件配置实现 ...
- ie 9 渐变背景色兼容问题
/*窗口背景*/ .window { background-color: #fff; background: -webkit-linear-gradient(top,#EFF5FF 0, ...
- 菜鸟学习Spring——SpringMVC注解版前台向后台传值的两种方式
一.概述. 在很多企业的开法中常常用到SpringMVC+Spring+Hibernate(mybatis)这样的架构,SpringMVC相当于Struts是页面到Contorller直接的交互的框架 ...
- java面试题之 -----面向切面编程
这种在运行时,动态地将代码切入到类的指定方法.指定位置上的编程思想就是面向切面的编程. 面向切面编程(AOP是Aspect Oriented Program的首字母缩写) ,我们知道,面向对象的特点是 ...
- 笨办法学Python(三十九)
习题 39: 列表的操作 你已经学过了列表.在你学习“while 循环”的时候,你对列表进行过“追加(append)”操作,而且将列表的内容打印了出来.另外你应该还在加分习题里研究过 Python 文 ...