node、Mongo项目如何前后端分离提供接口给前端
node接口编写,vue-cli代理接口方法
通常前端使用的MocK 数据的方法,去模拟假的数据,但是如果有node Mongodb 去写数据的话就不需要在去mock 数据了,具体的方法如下。
首先启动 mongodb、node、以及前端 项目。这里用加载商品列表做一个举例
1、在node项目创建
在node的项目中,创建文件夹: model。在model中创建 goods.js。在router 文件夹下创建 goods 的路由 goods.js。
2、模板goods.js编写(model下边的goods.js)
var mongoose = require('mongoose');
// 引入商品模型
var Schema = mongoose.Schema; // 定义商品模型
var productSchema = new Schema({
"productId": String,
"productName": String,
"salePrice": Number,
"productPic": String,
"checked": String
}); /**
* 输出 good 模型
* 有一个问题:在这里输出的是 good 但是数据库建立的一定要加s,代码会默认取数据库找 s 的那张表
*/
module.exports = mongoose.model('Good', productSchema);
3、在项目的app.js中配置 路由。
// 首先导入 goods 的路由文件
var goods = require('./routes/goods'); // 然后使用路由 // 新增路由商品,这个文件中的都是一级路由,这个路由到router下边的good,然后router那个good二级路由到 model 下边的goods
app.use('/goods', goods);
4、路由goods的编写。首先我们先确定连接数据库成功,然后再去数据库里面查找数据写接口
var express = require('express');
var router = express.Router(); var mongoose = require('mongoose');
var Goods = require('../model/goods'); /* 连接数目库. */
mongoose.connect('mongodb://127.0.0.1:27017/mall', {
useMongoClient: true
}); // 连接成功回调监听
mongoose.connection.on("connected", function(){
console.log("mongodb connected success");
}); // 连接失败回调监听
mongoose.connection.on("error", function(){
console.log("mongodb connected faile");
}); // 连接断开回调监听
mongoose.connection.on("disconnected", function(){
console.log("mongodb connected disconnected");
}); /**
* app.js 下边写的路由是一极路由,在这里写的路由是二级路由
* 例如:app.js 里面写的 /goods 这是一个路由地址了,下边写的 / 就是 /goods/ 默认加载的
* 这段代码的意思是:访问 http://1·27.0.0.1:3000/goods/ 其实就相当于是 Node 在这个地址里面 把前端想要的数据返回出来,这样前端调用这个地址就相当于是接口了
* 这块的路由就是 直接地址到/goods 然后再到 /
*/
router.get("/", function(req, res, next){
res.send("数据库连接成功");
}); module.exports = router;
这个时候重启一下 node 的服务,可以先关掉前便开启的服务,然后重启。
打开应该是
http://localhost:3000/
然后输入
http://localhost:3000/goods/
如果页面输出:数据库连接成功。则代表数据库连接成功了。这个时候便可以写我们的业务逻辑了,还是在router 下边的 goods.js中,整体代码应该是
/**
* app.js 下边写的路由是一极路由,在这里写的路由是二级路由
* 例如:app.js 里面写的 /goods 这是一个路由地址了,下边写的 / 就是 /goods/ 默认加载的
*/
router.get("/", function(req, res, next){ /**
* 连接请求处理数据 0 代表成功,1代表失败
* doc 就是返回的数据
*/ Goods.find({}, function(err, doc){
if(err){
res.json({
status: '',
msg: err.message
});
}else{
res.json({
status: '',
msg: '',
result: {
count: doc.length,
list: doc
}
});
}
});
});
这样重新启动node 然后输入地址变会出现,从数据库查找的 商品的 数据。
vue-cli代理接口方法
这个时候我们的商品数据的后端代码就差不多写完了;接下来就是把 接口放到前端去。因为我们的访问的还是 本地的接口,前后端项目又分离,这样前端访问这个接口其实还是牵扯到跨域的问题的,这样就需要在前端的项目中设置代理,来访问到接口了。
具体方法为:
用vue的项目做例子,把以前的mock数据的代码都去掉,在新的vue常见的项目中的config 下边的 index.js中 找到 dev,添加
// 设置代理
proxyTable: {
'/goods':{
target:"http://localhost:3000",//设置你调用的接口域名和端口号 别忘了加http 相当于是 访问/goods的时候,默认前边的端口就是 target 里面写的
}
}
意思就是当我们在项目中访问 goods这个接口的时候,自动代理到
http://localhost:3000/goods/
重新启动项目
npm run dev
看是否看到新的数据,整体就完了。
node、Mongo项目如何前后端分离提供接口给前端的更多相关文章
- 前后端分离,如何在前端项目中动态插入后端API基地址?(in docker)
开门见山,本文分享前后端分离,容器化前端项目时动态插入后端API基地址,这是一个很赞的实践,解决了前端项目容器化过程中受制后端调用的尴尬. 尴尬从何而来 常见的web前后端分离:前后端分开部署,前端项 ...
- springBoot 搭建web项目(前后端分离,附项目源代码地址)
springBoot 搭建web项目(前后端分离,附项目源代码地址) 概述 该项目包含springBoot-example-ui 和 springBoot-example,分别为前端与后端,前后端 ...
- RESTful、共用接口、前后端分离、接口约定的实践 (转)
出处: 某小公司RESTful.共用接口.前后端分离.接口约定的实践 前言 随着互联网高速发展,公司对项目开发周期不断缩短,我们面对各种需求,使用原有对接方式,各端已经很难快速应对各种需求,更难以提 ...
- vue项目实践-前后端分离关于权限的思路
前后端分离后权限的思路 最近看到许多关于权限的思路,但好像都是使用动态加载路由的方式,现在也分享下我在项目中使用的解决方案. 前后端分离关于权限的处理每个人都不一样,根据项目选择制定合适的方案就好 我 ...
- SpringBoot电商项目实战 — 前后端分离后的优雅部署及Nginx部署实现
在如今的SpringBoot微服务项目中,前后端分离已成为业界标准使用方式,通过使用nginx等代理方式有效的进行解耦,并且前后端分离会为以后的大型分布式架构.弹性计算架构.微服务架构.多端化服务(多 ...
- 某神秘公司 RESTful、共用接口、前后端分离、接口约定的实践
阅读本文大概需要 4.6 分钟. 本文来自 https://juejin.im/post/59eafab36fb9a045076eccc3 前言 随着互联网高速发展,公司对项目开发周期不断缩短,我们面 ...
- Django:前后端分离后联调给前端传数据
实现前后端分离后,有了下面几点改变: 1.服务器一分为二,前后端分别部署,静态资源放在前端服务器,业务代码放在后的服务器 2.前端服务器需要接收Http请求(一般使用node.js) 3.前端服务器需 ...
- 某小公司RESTful、共用接口、前后端分离、接口约定的实践
作者:邵磊 juejin.im/post/59eafab36fb9a045076eccc3 前言 随着互联网高速发展,公司对项目开发周期不断缩短,我们面对各种需求,使用原有对接方式,各端已经很难快速应 ...
- 前后端分离,接口API,契约
前后端分离了,然后呢? http://icodeit.org/2015/06/whats-next-after-separate-frontend-and-backend/ Swagger - 前后端 ...
随机推荐
- poj3233 题解 矩阵乘法 矩阵快速幂
题意:求S = A + A2 + A3 + … + Ak.(mod m) 这道题很明显可以用矩阵乘法,但是这道题的矩阵是分块矩阵, 分块矩阵概念如下:当一个矩阵A中的单位元素aij不是一个数值而是一个 ...
- 1393 0和1相等串 51nod
1393 0和1相等串 基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题 收藏 关注 给定一个0-1串,请找到一个尽可能长的子串,其中包含的0与1的个数相等. I ...
- cppunit 的使用
原文: http://blog.csdn.net/abcdef0966/article/details/5699248
- POJ2584_T-Shirt Gumbo(二分图多重最大匹配/最大流)
解题报告 http://blog.csdn.net/juncoder/article/details/38239367 题目传送门 题意: X个參赛选手,每一个选手有衣服大小的范围,5种大小的队服,求 ...
- jsp param动作标签
param 标签以"名字-值"对的形式为其它标签提供附加消息.这个标签与jsp:include.jsp:forward.jsp:plugin标签一起使用. param 动作标签 & ...
- HTML5开发移动web应用——SAP UI5篇(7)
SAPUI5中支持利用Component对组件进行封装.想封装一个组件,Component的基本代码例如以下: sap.ui.define([ "sap/ui/core/UIComponen ...
- MapReduce:具体解释Shuffle过程
Shuffle过程是MapReduce的核心,也被称为奇迹发生的地方.要想理解MapReduce, Shuffle是必需要了解的.我看过非常多相关的资料,但每次看完都云里雾里的绕着,非常难理清大致的逻 ...
- Python基础--正則表達式基本的语法以及re模块
正则是个非常牛逼的东西,python中当然也不会缺少. 所以今天的Python就跟大家一起讨论一下python中的re模块. re模块包括对正則表達式的支持. 什么是正则: 正則表達式是能够匹配文本片 ...
- 对扩展openflow协议的一点思考
软件定义X变得越来越火,正所谓,Software is eating the world. 软件定义网络也是如此.不论是在工业界还是学术界都将是一次伟大的革命,都在紧随着这个行业的方向,找自 ...
- HDU 5536/ 2015长春区域 J.Chip Factory Trie
Chip Factory Problem Description John is a manager of a CPU chip factory, the factory produces lots ...