前一段时间做了一个小项目,时间比较紧,就一个人月。最终希望能够通过微信公众号链接启动应用。

项目的业务细节就不多说了,主要是想分享一下做这个项目技术方面的一些经验。

技术选型

参考范围大致三种:AngularJS,Angular,React。

这里可能会有些困惑,AngularJS和Angular不是一个东西吗?

没错,它们是一个东西,但也不是一个东西。好了,废话少说,首先说明一下AngularJS和Angular的区别。

引用官方文档中的一句话

Angular is the name for the Angular of today and tomorrow. AngularJS is the name for all v1.x versions of Angular.

这回很清晰了。

Angular:指的是 v2.x 及以后的版本

AngularJS:特指 v1.x

由于Angular从2.0以后版本更新比较大,所以为了做区分,只能想出这么一招了。

好了,回归正题,这三种技术怎么选择?

以下是我当时的考虑:

AngularJS:由于之前两个项目一直在用AngularJS,所以使用起来并不陌生,相对buffer也会少很多(前面说了,时间比较紧,只有一个月)。碰到问题还可以和大家商量一下。

但是AngularJS性能及体积是个问题,尤其是要在手机端运行。

Angular: 性能不是问题,体积也还好。但是接触比较少,之前只做过一个Web端的项目。

React: 前一段时间刚刚研究过,性能,体积都不是问题。但是同Angular一样,没有实际项目经验啊,出了问题就只能百度了。

经过以上的一番权衡,其实我心里是想用React的。其中一个原因是经过前一段时间的学习,很想通过一个项目积累一些React的开发经验,

另外一个原因是React无论从性能上(得益于Virtual DOM)还是思想上(组件化)都更为先进。

基于以上两点原因,所以在和项目经理确定技术选型的时候,我极力推荐React,虽然可能会存在一些buffer,但是从可持续化发展的角度考虑(自己瞎猜的...),最终项目经理同意了。

项目框架搭建

在GitHub上看了很多的boilerplate工程,或多或少都和自己的需求有些出入。

所以,最终自己通过React官方的create-react-app cli搭建了一个seed工程。

1. 准备环境

node.js

2. 安装creat-react-app cli

  1. npm install -g create-react-app

3. 创建工程

  1. create-react-app react-seed

然后进入项目根目录react-seed安装相关依赖

  1. cd react-seed
  2. npm install

4. 暴露配置项

由于采用create-react-app创建的项目webpack等配置信息都是封装好的,所以为了灵活修改相关配置,可以通过以下命令让封装好的配置文件暴露出来。

  1. npm run eject

创建好的项目目录如下:

5. 本地服务启动

  1. // 启动本地server用于开发
  2. npm run start

将会在本地 3000 端口启动

redux集成

熟悉React的可能都知道,React是单向数据流,所以有些情况下单单依赖React自身无法实现组件之间的通信,这时就需要Redux登场了。

本文不介绍Redux的语法及思想,只说明如何集成。

首先需要安装Redux相关依赖,由于不同版本之间可能存在兼容性问题,所以安装的时候最好制定版本:

  1. npm install redux@3.7.2 --save
  2. npm install redux-thunk@2.1.0 --save
  3. npm install react-redux@5.0.6 --save

然后就可以在项目中引入redux了,可以像如下方式组织目录结构:

路由集成

react-router

  1. npm install react-router@3.0.5 --save

路由支持嵌套,代码如下:

  1. const routes = (
  2. <Router history={hashHistory}>
  3. <Route path="/home" component={Layout} onEnter={onEnter}>
  4. <IndexRoute getComponent={home} onEnter={onEnter}/>
  5. <Route path="/home" getComponent={home} onEnter={onEnter}/>
  6. <Route path="/detect" getComponent={detect} onEnter={onEnter}/>
  7. <Route path="/about" getComponent={about} onEnter={onEnter}/>
  8. </Route>
  9. <Route path="/unauthorized" getComponent={unauthorized}/>
  10. <Redirect from="*" to="/home" />
  11. </Router>
  12. );
  13. export default routes;

国际化方案

采用的是常用的react-intl

  1. npm install react-intl@2.4.0 --save

UI组件集成

基于React的UI组件在这里推荐两个,一个是蚂蚁金服的Ant Design;另外一个是Material-UI

两个都很不错,本人使用的是Ant Design。

  1. npm install antd@2.13.10 --save

fetch集成

关于请求数据有很多种方式,本人用的是fetch

  1. npm install fetch@1.1.0 --save

可以简单封装一下,如下:

  1. import 'whatwg-fetch'
  2. import loggerService from './logger'
  3. let notAuthorizedCounter = 0;
  4. let fetchService = {
  5. fetch: (url, method, header, body) => {
  6. if (!header) {
  7. header = {}
  8. }
  9. return fetchService[method.toLowerCase()](url, header, body).catch(function(exception) {
  10. loggerService.log('fetchService failed:', exception);
  11. // token过期,重新获取token并发起请求
  12. if (exception.code === '401' || exception.code === '403') {
  13. notAuthorizedCounter++;
  14. // 最多重试3次
  15. if (notAuthorizedCounter > 2) {
  16. notAuthorizedCounter = 0;
  17. loggerService.warn("401 or 403 received. Max attemps reached.");
  18. return;
  19. } else {
  20. return fetchService.fetch(url, method, header, body);
  21. }
  22. }
  23. });
  24. },
  25. get: (url, header) => {
  26. return fetch(url, {
  27. method: 'GET',
  28. headers: header
  29. }).then((response) => {
  30. return response.json();
  31. });
  32. },
  33. post: (url, header, body) => {
  34. header['Content-Type'] = 'application/json';
  35. return fetch(url, {
  36. method: 'POST',
  37. headers: header,
  38. body: JSON.stringify(body)
  39. }).then((response) => {
  40. return response.json();
  41. });
  42. }
  43. };
  44. export default fetchService;

项目部署

首先对项目进行打包。

  1. npm run build

可以通过以下命令在本地环境运行打包后的项目。

  1. serve -s build
注意:

如果项目中引入路由的时候使用的是BrowserRouter,
那么当执行npm run build打包之后,本地打开index.html文件,会出现空白页面。

原因是BrowserRouter是用浏览器history对象的方法去请求服务器,

如果服务器没有配置相对应的路由去指向对应的页面,路由会找不到资源。

BrowserRouter会变成类似这样的路径http://111.230.139.105:3001/detail/9459469, 这样的路径在访问服务器时,服务器会认为是请求查找某个接口数据。

所以这时候必须使用HashRouter,这时候访问具体页面时就是http://111.230.139.105:3001/#/detail/9459469


项目源码已经开源到github上,喜欢的给个Star支持下吧!(_

react-seed

React项目模板-从项目搭建到部署的更多相关文章

  1. Maven用项目模板生成项目

    Archetype插件是Maven生成项目的项目模板,项目模板就是一个框,把文件夹这些定好,然后就可以在上开写具体逻辑等等. 最常用的命令: mvn archetype:generate 这个是生成一 ...

  2. Cookiecutter: 更好的项目模板工具:(1)简介及可用资源汇总

    原文档地址:https://cookiecutter.readthedocs.io/en/latest/ 本系列只介绍cookiecutter的基础使用,而且会删除与功能使用无关的部分.深度使用及了解 ...

  3. vs多项目模板及add-in开发

    本文分2部分 第一为自定义多项目模板 第二为vs add-in开发 效果图 1.自定义模板 2. 工具菜单 3.窗口 4.工程 5.文件 ... 一. 多项目模板 单项目模板做起来很简单 选中一个项目 ...

  4. Win10系列:JavaScript 项目模板和项模板

    使用Visual Studio 开发Windows应用商店应用时,通过其提供的模板可以帮助我们快速地创建一个应用.其中,在新建一个Windows应用商店应用程序项目时可以在项目模板中选择所需要的模板类 ...

  5. React项目搭建与部署

    React项目搭建与部署 一,介绍与需求 1.1,介绍 1.1.1,React简介 React 是一个用于构建用户界面的 JAVASCRIPT 库. React主要用于构建UI,很多人认为 React ...

  6. Vue项目搭建与部署

    Vue项目搭建与部署 一,介绍与需求 1.1,介绍 Vue  是一套用于构建用户界面的渐进式框架.与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用.Vue两大核心思想:组件化和数据驱动.组 ...

  7. jenkins+git+maven搭建自动化部署项目环境

    简介    折腾了两个晚上,趁着今晚比较有空,把jenkins+git+maven搭建自动化部署项目环境搭建的过程记录一下,这里我把github作为git的远程仓库(https://github.co ...

  8. Vue.js项目模板搭建

    前言 从今年(2017年)年初起,我们团队开始引入「Vue.js」开发移动端的产品.作为团队的领头人,我的首要任务就是设计 整体的架构 .一个良好的架构必定是具备丰富的开发经验后才能搭建出来的.虽然我 ...

  9. SpringMVC框架下Web项目的搭建与部署

    这篇文章已被废弃. 现在,Deolin使用Maven构建项目,而不是下载Jar文件,使用Jetty插件调试项目,而不是外部启动Tomcat. SpringMVC比起Servlet/JSP方便了太多 W ...

随机推荐

  1. mybatis sql循环的使用

    foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合. foreach元素的属性主要有 item,index,collection,open,separator,close. ...

  2. Tomcat软件使用常见问题

    Tomcat软件使用常见问题 tomcat软件使用的常见问题 1)闪退问题 原因:tomcat软件是java语言开发的. tomcat软件启动时,会默认到系统的环境变量中查找一个名称叫JAVA_HOM ...

  3. TIJ笔记:内部类的初始化

    看编程思想有点时间了,看到了些在马士兵老师没有讲过的部分,所以打算记录一下 内部类的初始化: .内部类的初始化和外部类的初始化略有不同,可以使用 外部类对象.new 内部类对象 创建内部类对象 pac ...

  4. PHP网站从Apache转移到Nginx后产生404错误的原因和解决办法

    原案例分析: 1.原来的网站在wamp环境下搭建完成,一切正常,上传到虚拟主机环境为lnmp,结果访问时可以打开主页,然后点其他页面全部报404错误: 2.经分析得出原因:原网站环境为wamp使用了伪 ...

  5. async函数解析

    转载请注明出处:async函数解析 async函数是基于Generator函数实现的,也就是说是Generator函数的语法糖.在之前的文章有介绍过Generator函数语法和异步应用,如果对其不了解 ...

  6. J.U.C atomic AtomicInteger解析

    很多情况下我们只是需要简单的,高效,线程安全的递增递减方法.注意,这里有三个条件:简单,意味着程序员尽可能少的底层或者实现起来比较简单:高效,意味着耗用资源要少,程序处理速度要快: 线程安全也非常重要 ...

  7. es6重点笔记:数值,函数和数组

    本篇全是重点,捡常用的怼,数值的扩展比较少,所以和函数放一起: 一,数值 1,Number.EPSILON:用来检测浮点数的计算,如果误差小于这个,就无误 2,Math.trunc():取整,去除小数 ...

  8. bash中声明变量方法

    bash提供了declare命令来声明变量,该命令的基本语法如下: declare attribute variable      其中,attribute表示变量的属性,常用的属性有如下所述.   ...

  9. linux运维学习

    export 和unset 设置和取消变量 echo 的双引号和单引号的区别:双引号里的会被替换,单引号里的都会直接输出.

  10. jquery取前、后、父、子元素

    前.prev(); 后.next(); 父.parent(); 子.children(); 注意:前的前是.prev().prev(),例如前元素无i,但前的前的i元素有i,不能写成.prev('i' ...