React version 16.2 版本脚手架
包含客户端,服务端渲染完整示例,使用了最新的react,并实现version 16.2 最新的服务端渲染; 解决了一些之前的服务端渲染bug;并添加了调试的服务端渲染模式; 使用webpack 4.0 来编译
<!-- 分离的第三方依赖 --> <script src="../dist/js/vendor.js"></script> <!-- react --> <script src="../dist/js/app.js"></script>
安装命令和一些常用的npm脚本;
- yarn (安装脚手架依赖)
- yarn preinstall (检查node版本,最低8.0以上版本)
- yarn prestart (删除dist 编译打包文件)
- yarn start (启动客户端的开发环境)
- yarn build (打包编译客户端环境,并启动)
- yarn prod (启动并打包服务端渲染)
- yarn server (启动服务端渲染开发环境)
- yarn lint (检查代码规范)
- yarn lint:watch (检查代码规范并监听)
- yarn test (启动单元测试)
- yarn test:watch (启动单元测试并监听)
- yarn remove-dist (删除dist文件夹)
- yarn clean-dist (清空dist文件夹)
一些常见问题
- 部署到服务器上,需要Nginx 反向代理启动node.js 的http 服务;
- 刷新之后 404 或者子路由报错;是使用了 BrowserRouter这个路由或者分割了代码。这个路由会开启h5 的history 模式;所以需要Nginx的支持; Nginx uri 定向到例如是打包文件是通过index.html 就重定向到index.html;如果是放在index.PHP就重定向到index.PHP就不会有这个问题了;
- 服务端渲染的样式需要放在入口内。不是服务端渲染的就不用;
- 这个脚手架是封装了axios 这个ajax库到redux中;所以不用在调用的地方引入axios;只需要在redux的action中使用我在redux中封装的axios 中间件的别名 例如: api.get api.post等就好了;action中也符合redux的方式;
- 需要注意的是不是服务端渲染的启动命令也是不同的; 服务端渲染主要是为了解决SEO问题,因为是单页应用。必须用户点击打开index.html 或index.PHP 或者站点后才能加载打包后的js 文件开始渲染节点内容; 没有加载js 也就不能渲染出节点。也就不能被搜索引擎检索到; 这也就是服务端渲染的需要;另外服务端渲染也加快网页加载速度; 只要服务器压力能承受住;
- 为什么服务端渲染不分割代码。因为会报错;而且用了压缩代码会小很多;普通十多张页面不会超过1MB .1Mb对于服务端来说并没有什么..
更新日志(2018.03.07)
- 优化父子路由的写法。 父路由嵌套子路由
- 解决了服务端之前存在的报错问题。并加入服务端渲染调试模式,
- 优化redux路由数据在服务端渲染的时候不同步问题;
- 增加redux axios 中间件调用方法;以及调用获取数据例子
- 增加 使用react-router-redux 编程式导航的例子;通过代码跳转到页面返回上级页面;并保证redux的数据同步,不会延迟;
- webpack 升级到webpack version 4.1.0;
- 移除mocha 测试.使用更加简单的jest来处理测试
- 更新webpack-dev-middleware与 webpack-hot-middleware,