手把手教你webpack、react和node.js环境配置(下篇)
上篇我介绍了前端下webpack和react、redux等环境的配置,这篇将继续重点介绍后台node.js的配置。
这里是上篇链接:手把手教你webpack、react和node.js环境配置(上篇)
我把所有代码都放到了我的github上:webpack-react-express环境配置
server
后台这边的配置就简单了很多,我这里拿node.js的express框架来配置。
express
Express 是一个基于 Node.js 平台的极简、灵活的 web 应用开发框架,它提供一系列强大的特性,帮助你创建各种 Web 和移动设备应用。
安装express
npm install express --save
在这里我推荐一个express应用生成器,会帮你自动生成express项目的目录。
npm install express-generator -g
所以在这里我们将此前创建好的server文件夹删除,然后用express自动生成。
rm -rf server && express server
我们先删除自动生成的不需要的目录。
rm -rf views && public
这时候会发现server目录下面也有一个package.json文件,这个文件保存着express需要的依赖,我们可以把里面的内容合并到外面的package.json里面然后再删除,然后不要忘了用npm install来重新安装一遍里面的模块。
我们打开app.js文件,发现里面已经已经写好了代码,但是这些代码并不是完全符合我们需求,比如我们不想使用jade或ejs模板引擎,我们想用前后端分离的开发方式,只想render一个html,我们需要修改一下代码。
因为要用到ejs的一个功能,所以先安装ejs。
// 自动生成的代码
app.set('views', path.join(__dirname, 'views')); // 设置模板的路径
app.set('view engine', 'jade');
app.use(express.static(path.join(__dirname, 'public')));
// 我们修改后的
app.set('views', path.join(__dirname, '../client/dist'));
app.set('view engine', 'html'); // 将模板设置为html
app.engine('html', ejs.renderFile);
app.use(express.static(path.join(__dirname, '../client/dist')));
然后我们删除掉自动生成的路由信息,改为我们的:
// 删掉这些
var index = require('./routes/index');
var users = require('./routes/users');
app.use('/', index);
app.use('/users', users);
// 然后添加
var port = 4000;
app.all("*", function(req, res) {
res.render("index");
})
app.listen(port, function() {
console.log("server is running on port 4000");
});
这时候,我们只需要在命令行里面输入node app.js就可以跑了。
但是这样还没完,我们每次运行node是不是都要到server目录下面?我用的不是node新版本,但是我想用es6的语法怎么办?
在express里面使用es2015
还记得上篇我们单独提取出来一个.babelrc文件吗?这个里面已经设置了转码规则,babel-cli自带了一个babel-node命令,它让在node环境里面运行es6的语法成为可能。
开始前我先安利一下nodemon,它可以让node自动重启,而不需要我们每次手动重启node。
npm install nodemon -g
它的用法和node一样,我们可以直接nodemon app.js来开启node服务,当你修改node代码时,它会自动重启node。
我们需要修改一下package.json文件,在scripts属性里面添加一个start属性,并添加以下代码:
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"start": "nodemon ./server/app.js --exec babel-node"
},
把代码修改为es6的语法:
这个时候我们不仅可以在express里面使用最新的es语法,还可以直接用npm start命令来开启node服务。
手把手教你webpack、react和node.js环境配置(下篇)的更多相关文章
- 手把手教你webpack、react和node.js环境配置(上篇)
很多人刚学习react的时候,往往因为繁琐的配置而头疼,这里我将手把手教大家怎么用webpack配置react和redux的环境,这篇教程包括前端react和后台node整个网站的环境配置,对node ...
- windows系统下简单node.js环境配置 安装
国内目前关注最高,维护最好的一个关于nodejs的网站应该是http://www.cnodejs.org/ windows系统下简单nodejs环境配置. 第一步:下载安装文件 下载地址:官网 htt ...
- 185.nvm和node.js环境配置
安装nvm nvm(Node Version Manager)是一个用来管理node版本的工具,我们之所以使用node,是因为我们需要使用node中的npm(Node Package Manager) ...
- node.js环境配置(angularjs高级程序设计中出现的错误)
一:npm install connect会出现错误:解决方法 1:$ npm install connect@2.X.X 2:$ npm install serve-static: 建立server ...
- 手把手教windows上安装linux虚拟机及环境配置
目录 版本说明 安装虚拟机 典型方式安装(推荐小白,带有图形界面,助于学习,但占用空间大) 自定义方式安装(推荐老司机) 创建快照 克隆虚拟机 windows上安装linux虚拟机不管是对于新人还是老 ...
- 使用React、Node.js、MongoDB、Socket.IO开发一个角色投票应用的学习过程(三)
这几篇都是我原来首发在 segmentfault 上的地址:https://segmentfault.com/a/1190000005040834 突然想起来我这个博客冷落了好多年了,也该更新一下,呵 ...
- 认识Web前端、Web后端、桌面app和移动app新开发模式 - 基于Node.js环境和VS Code工具
认识Web.桌面和移动app新开发模式 - 基于Node.js环境和VS Code工具 一.开发环境的搭建(基于win10) 1.安装node.js和npm 到node.js官网下载安装包(包含npm ...
- Node.js环境搭建&&npm安装
Node.js环境搭建 什么使Node.js呢?我们知道JavaScript开始作为客户端语言,但早已在浏览器端一统江湖,这时,野心越来越大,它就想向服务器端拓展了,于是Node.js就是这样的,我们 ...
- node.js环境安装,及连接mongodb测试
1.node.js环境安装 npm config set python python2.7npm config set msvs_version 2013npm config set registry ...
随机推荐
- 【单调栈】hdu1506 Largest Rectangle in a Histogram
单调栈的介绍及一些基本性质 http://blog.csdn.net/liujian20150808/article/details/50752861 依次把矩形塞进单调栈,保持其单增,矩形中的元素是 ...
- js原生设计模式——9外观模式封装2(小型代码库YJ)
<script type="text/javascript"> //小型代码库YJ封装 var YJ = { //根据id获取元素 ...
- SpringMVC 前端获得定义JSON对象的方法
SpringMVC 前端获得定义JSON对象的方法: 可以使用map进行对象的创建,这样就会解析成键值对,不需要为前端专门定义对象.
- 比AutoMapper轻量快速简洁的实体映射库YeaJur.Mapper
之前在做实体深拷贝时一直使用的AutoMapper,但是总是觉得其写法比繁琐,效率也不算很高,自己写了一个轻量级的实体拷贝库YeaJur.Mapper,和AutoMapper 测试对比如下 PK项 Y ...
- linux 中c/c++实现终端命令行命令
在终端中可以从用下面命令获得帮助: man system 在c/c++代码中实现和在终端中输入的命令行一样的效果,以命令(audacious -p &)为例,该代码实现用audacious在后 ...
- 如何增强ArcGIS插值图出图效果
如何增强ArcGIS插值图出图效果 by 李远祥 在一些科研领域,经常会遇到使用插值的方式进行处理,并生成最终的插值图.插值图在ArcGIS里面非常容易生成,只要具备了采用点数据,通过ArcToolB ...
- 使用python制作ArcGIS插件(2)代码编写
使用python制作ArcGIS插件(2)代码编写 by 李远祥 上一章节已经介绍了如何去搭建AddIn的界面,接下来要实现具体的功能,则到了具体的编程环节.由于使用的是python语言进行编程,则开 ...
- SQL SERVER运维日记--收缩数据库
一个小故事 某天,小王正在和HR妹妹闲聊,正HAPPY时,,突然收到系统告警消息,数据库磁盘被剩余空间500M,OMG,不行,磁盘快满了,要是业务要停了,,那就小王只能删库到跑路了,,, 先检查下,有 ...
- UITableView、UICollectionView行高/尺寸自适应
UITableView 我们都知道UITableView从iOS 8开始实现行高的自适应相对比较简单,首先必须设置estimatedRowHeight给出预估高度,设置rowHeight为UITabl ...
- Android系统之灯光系统--通知灯深入分析
Android通知灯的深入分析 通知的类别 声音 振动 闪灯 APP如何发出通知灯请求 getSystemService(通知服务) 构造notification 类别 其他参数(颜色,onMS,of ...