react-webpack-express
这是一个整合react express 实现前后台交互,并且采用webpack进行打包和解析文件。其实react官方有一个脚手架create react app,也可以看那个,但是这个脚手架webpack.config.js这个在文件夹中并没有,应该是整合到安装包里面去了。总的来说还是自己弄一个脚手架比较好,想添加什么功能都可以。
一、需要提前安装的:
node npm
二、需要下载的包:
npm install --save-dev react react-router react-dom
npm install --save-dev express
npm install --save-dev webpack
新建一个webpack.config.js文件,这个文件是针对打包用的
三、项目结构

四、简要说一下思路
安装好基本的包之后。新建上面说的那些文件和文件夹,我们就需要更改package.json中命令,设置一个npm start对应的是执行dev-server.js文件,这个文件里面,引入webpack.config.js和写监听端口的代码,这时候我们就需要编写webpack.config.js了,我们设置一个app.jsx作为入口文件,在webpack.config.js中,引入解析js jsx css文件的包(先弄基本的文件)。最后再src中写一个jsx文件,将这个文件中的组件用es6 modules输出到app.jsx文件中。
其实上面已经实现了,但是我们需要实现热更新,这里面我们需要用到引入webpack-dev-middleware和webpack-hot-middleware进行热更新,具体可以看下面
这就是基本的实现的思路,其实有个大概的思路了,一步一步的走,然后遇到不会的了,谷歌百度就查吧(强烈建议用谷歌,百度我都要放弃了,什么都查不出来,找个vpn翻墙去)
五、具体介绍(一到具体就不知道该写啥。。。按照上面思路来吧)
1.package.json 这个文件放的主要需要咱们看的是一开始执行的命令:
"scripts": {
"build": "webpack",//这是走的是webpack.config.js文件,这是开始上线了 我们需要将文件全部构建打包
"start": "node ./dev-server.js",//这个是我们开发的时候需要执行的文件 执行的命令是npm start
"test": "echo \"Error: no test specified\" && exit 1"
},
2,因为我们开发的时候执行的是npm start,所以我们开始看dev-server.js文件,这个几个工作是:(1)监听端口 (2)引入webpack.config.js (3)引入后台的api
var express=require('express');
var app=express();
var api=require('./server/api.js');
var bodyParser=require('body-parser');
//获取到客户端传的参数
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended:false}));
//获取到后台的api
app.use(api);
app.use('/',require('connect-history-api-fallback')());
app.use('/',express.static('public'))
//如果是开发模式的话
if(process.env.NODE_ENV!=='production'){
//引入webpack模式
var webpack=require('webpack');
var webpackConfig=require('./webpack.config.js');
var webpackCompiled=webpack(webpackConfig);
var webpackDevMiddleware=require('webpack-dev-middleware');//webpack-dev-middleware结合webpack-hot-middleware实现热重载开发服务器,但是这个是直接将代码放在内存中的
app.use(webpackDevMiddleware(webpackCompiled,{
publicPath:'/',
stats:{color:true},
lazy:false,
watchOptions:{
aggregateTimeout:300,
poll:true
},
}));
//配置热更新
var webpackHotMiddleware=require('webpack-hot-middleware');
app.use(webpackHotMiddleware(webpackCompiled));
}
//监听端口
var server=app.listen(2000,function(){
var port=server.address().port;
console.log(port)
console.log('http://localhost:%s',port);
})
3.然后我们看到引入了webpack.config.js文件,开始看webpack.config.js文件。这个文件主要是引入入口文件,和进行打包,在loader里面针对不同文件进行文件解析,还有就是需要加一个引入webpack-dev-middleware和webpack-hot-middleware进行热更新(热更新)
4.在webpack.con里面我们需要有一个入口文件,因为将组件渲染到页面中,需要将组件和根元素获取到,这个里面就是将路由和根元素放在ReactDOM.render()里面,根元素就不用说了,就是你的html模板文件里面自己设置的,然后就是我们需要看看路由文件
5.路由文件我使用的是React-router4.2.0这个和之前的有区别,路由知道之后我们就需要根据路由创建对应的组件
=======到此是前台代码,下面我们说一下后台代码
6.server文件夹里面放的就是后台代码,后台用的是express 数据库用的是mongodb,我们先看db.js
下载一个mongoose这个模块,链接上mongodb,然后,创建模型和对象,输出到api.js
7.现在看一下api.js文件,这个文件是设置后台接口的文件,我们从db.js里面获取到数据库中集合的对象,然后通过express的路由中间件,设置对象功能的接口。
8.我们将api.js文件引入到dev-server.js文件中,app.use(api)
======到此是后台代码
======自己写一个项目,源代码在:https://github.com/GainLoss/react-webpack-express
项目中遇到的情况:
1.父组件发生事件,重新渲染子组件:
父组件点击事件,将state中的key值改变,进行赋值;并且在子组件中的componentWillReceiveProps(nextProps)中进行需要的操作。这样就开始重新渲染子组件了
react-webpack-express的更多相关文章
- 真刀实战地搭建React+Webpack+Express搭建一个简易聊天室
一.前面bb两句 因为自惭(自残)webpack配置还不够熟悉,想折腾着做一个小实例熟悉.想着七夕快到了,做一个聊天室自己和自己聊天吧哈哈.好了,可以停止bb了,说一下干货. 二. 这个项目能学到啥? ...
- react+react-router+webpack+express+nodejs
react+react-router+webpack+express+nodejs 做SinglePageApplication 支持热加载+ES6 有开发模式和发布模式 https://gith ...
- 部署React+webpack工程的步骤
# 部署React+webpack工程的步骤ps:以Mac os系统做开发环境.因为npm现在使用灰常的慢,所以我使用淘宝境像cnpm. 1,准备工作: 先确保存已经安装了node.js: 2,文件部 ...
- scss + react + webpack + es6
scss + react + webpack + es6 写在前面: 刚学习完慕课网里的一个幻灯片案例,自己加了刚学的react,两者结合.首先让大家看看效果 点击此处 你可以先用纯js实现上面的效果 ...
- react +webpack 配置px2rem
项目背景需要适配ipad 以及手机端,这时候当然要告别刀耕火种时代啦(自己算rem),因为已经有成熟的工具啦,即px2rem(https://www.npmjs.com/package/px2rem) ...
- NodeJS + React + Webpack + Echarts
最近画了个简单的前端图,使用百度的echarts,基于原来项目的NodeJS+React+Webpack框架.在此记录一下: 1. 在react里封装echarts组件,并调用后端API. (参考的 ...
- react+webpack+babel环境搭建
[react+webpack+babel环境搭建] 1.react官方文档推荐使用 babel-preset-react.babel-preset-es2015 两个perset. Babel官方文档 ...
- 如何在react&webpack中引入图片?
在react&webpack项目中需要引入图片,但是webpack使用的模块化的思想,如果不进行任何配置,而直接在jsx或者是css中使用相对路径来使用就会出现问题,在webpack中提供了u ...
- react+webpack 引入字体图标
在使用react+webpack 构建项目过程中免不了要用到字体图标,在引入过程中报错,不能识别字体图标文件中的@符,报错 Uncaught Error: Module parse failed: U ...
- React + webpack 快速搭建开发环境
因网上大多React + webpack快速搭建的运行不起来,便自行写了一个.在搭建开发环境的前需安装nodejs,npm. 新建一个工作目录,比如叫reactdome,在reactdome目录中运行 ...
随机推荐
- 不要重复发明轮子-C++STL
闫常友 著. 中国铁道出版社. 2013/5 标准的C++模板库,是算法和其他一些标准组件的集合. . 1.类模板简介 2.c++中的字符串 3.容器 4.c++中的算法 5.迭代器 6.STL 数值 ...
- Win10如何新建用户怎么添加新账户
https://jingyan.baidu.com/article/25648fc162d5899190fd0069.html 很多朋友都是安装完Windows10系统后,直接使用超级管理员账号登录系 ...
- 经常谈到Oracle的权限,你究竟知道多少
作者: 三十而立 时间:2009年10月28日 9:41:15 请尊重原创作品.转载请保持文章完整性,并以超链接形式注明原始作者"inthirties(三十而立)" 接着上面谈到的 ...
- 【记录】SQL注入过滤源码分享
$id=check_addslashes($_GET['id']);$id= preg_replace('/o*r/i',"", $id); //strip out OR (non ...
- 千图网爬图片(BeautifulSoup)
import requests from bs4 import BeautifulSoup import os #导入os模块 class TuKuSpider(): ""&quo ...
- 图解DTS和PTS
由于把视频编码成I,B,P等帧,如下图 假设现在有I,B,P帧,那么要传输和显示呢?? 如果按照显示顺序传输的话: 传输顺序就是I->B>P 当对B帧进行解码后,由于B帧无法单独显 ...
- Nginx设置日志分割方法
目标:nginx cronolog日志分割配置文档,每分钟分割一次NGINX访问日志. 大体步骤如下: 1.nginx日志配置 access_log /var/log/nginx/access.log ...
- AI从入门到放弃:CNN的导火索,用MLP做图像分类识别?
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 作者:郑善友 腾讯MIG后台开发工程师 导语:在没有CNN以及更先进的神经网络的时代,朴素的想法是用多层感知机(MLP)做图片分类的识别:但 ...
- nyoj 206——矩形的个数——————【dp或公式】
矩形的个数 时间限制:1000 ms | 内存限制:65535 KB 难度:1 描述 在一个3*2的矩形中,可以找到6个1*1的矩形,4个2*1的矩形3个1*2的矩形,2个2*2的矩形,2个3 ...
- windows下libcurl+openssl编译与使用配置
之前使用过libcurl, 编译也是最简单的版本, 不需要openssl, 即不需要支持https, 所以编译和使用都很正常. 但要使用openssl就很麻烦了, 我花了差不多两天去编译和调用, 记录 ...