webpack2+react+react-router+react-redux+ES6+antd-mobile版本的Cnode

https://juejin.im/post/5902c98fda2f60005def88a2?utm_source=tuicool&utm_medium=referral

苦于我就职的公司的技术栈还是ES5+jQ+handelbars,
而我一直对React全家桶非常感兴趣,所以想自己来个强行实战,
见到react中国社区有几个CNode社区的react版本,
于是自己也计划了用CNode提供的API,从零开始做一个开源项目。
这个项目是我刚开始是写在github上的,用了一周左右从零学react,
然后清明节放假,哪也没去,做了这个非全功能版的CNode社区。

从开始熟悉react到完成这个作品,一共用了不到2周时间,
前提是我有一定的技术沉淀,所以新手也不要觉得2周很快。
也许对一些大牛来说,这已经比较慢了。

先上个作品地址,来扫码:


觉得还不错的话, 点这里给我一颗Star~
静态服务器是node搭的,PM2开启守护,不用再担心挂掉了。

2017.4.27给自己立两个flag,不定期会更新:

  • 改造hashHistory为browserHistory,包括服务端都自己来配置(宗旨是解决微信分享会截断#哈希地址的问题)。
  • 把react-router升级到4版本。

2017.4.6更新思维导图。

首页加载还是有一些可以优化的地儿耐心等一会儿吧~!

使用的技术栈:

webpack:更新到2版本,网上目前大多数webpack-react教程都是1版本的配置写法。
react:谁用谁知道。
react-router:激进的我一边查阅4版本的英文文档一边做demo,发现改动太大,国内连issue几乎都没有,所以我鸟悄的退回到3版本使用(后期会更新到4版本)。
react-redux:挑战所在,相当于在新的开发模式上再叠加新的东西。
ES6:以前自己学JAVA的时候就喜欢Class的写法,这次每写一个组件都爽咩哈哈。
antd-mobile:UI样式,阿里提供的antd的移动端实现,完美契合react,好用,好看。

几点心得:

  • 对常用jQuery/Zepto这类类库开发的开发者来说,react开发体验要好太多,webpack的强大功能使开发专注于代码,不用再考虑babel转好了ES6还要确定目录、sass还要用考拉或者filewatcher来处理、代码复用到底写在哪里才好...等问题。

  • 众多的贡献者,超高的社区活跃度,数不清的插件(这次项目中使用了许多,实在是太好用),react+webpack+ES6的技术栈可以给开发者长期浸淫的信心。

  • redux架构给我的体验还不错,多亏阮一峰老师的简明教程,这个教程是三部的,都需要认真看。这些教程让我可以快速掌握一些核心的使用方式以及提早要避免的坑,对应redux,我的项目结构是经过一番考究才定下来的。

  • 虽然react-redux建议UI不要带有任何自己的state,但实际业务中,灵活的使用UI本身的state是非常有利于开发的,不要为了使用redux而使用redux。另外,开发人员不是特多的话,reducer写在一个js里也不错,出了逻辑问题直接定位到这。action的type命名遵循一定规律,会给后期开发带来想不到的福利,比如这次的异步action‘fetch’,开发后期发现异步带来的问题有很多,需要一个全局控制,这时reducer配合正则表达式+遵循了一定规律的命名,很简单就实现了想要的。

  • 虽然可以很快就实现初级的项目,开发过程中,完全不考虑操作DOM的体验虽然好,但也带来了许多可能的不必要的重复渲染,react配合redux非常需要注意性能,reducer处理不好,经常会重复渲染,理解react的运作方式很重要,零活运用shouldComponentUpdate来使你的页面性能达到最好,本身这就是一个挑战,再加上redux的参与...经过一番努力,我才使所有的页面都禁止了不必要的渲染,这个优化我体现在了控制台里,你可以查看每页的渲染情况。

  • 实现回到长列表的上次滚动位置,着实耗费了我不少时间(我经常在react技术群里看到好多人提这个问题),想了许多种实现方式,最终通过ListView的initialListSize属性配合缓存,实现了几乎媲美原生的回退到上次列表位置的效果。还有antd的ListView重复触发又没有详细明确的解答的onEndReached事件问题,最终通过对异步的控制以及在render中做了一些非常规处理才解决。

  • 长列表的滚动延续动画无法控制,导致模仿iOS回到顶部的功能总是有缺陷,我有很多想法,比如:屏蔽掉原生事件,Touch.js之类的组件模拟。也可以单独弄个回到顶部的按钮出来,那样点击一次就会让滚动停下,第二次就可以回到顶部了(但是那样长得就不像原生的了)。 网上有很多长列表优化的文章,这个也是作为H5发开着需要着重研究的一个点,需要更深入的研究。也许在RN里能有更好的表现?所以,呃,研究RN势在必行。

  • 重要的首屏加载问题,在Gzip的淫威下,1.6M的bundle压缩后只有300多k,然后,webpack+react-router还能实现按需加载,在硬件不断进步的今天,越来越不是问题了,这已经是现实了,就像两年前我们还在担心有的老板想兼容IE6,如今淘宝都只支持IE9+了,我的梦想是,没有IE,哈哈哈哈。Gzip我是用webpack-dev-server开的,包括proxy也是用它开的,在开发角度来说,比ngnix还方便。以前用ngnix处理开发中的跨域,还要另外去动手(懒得不要不要的)。

  • 虽然英文水平可以勉强看英文文档,但无法像看中文文档那样自如浏览,一定程度上影响跟随国外优秀新版本技术的脚步,下一步也要强迫自己多贴近英文。

  • 因为接触的越多,觉得需要学习的越多,内心也是五味杂陈的,我还没女朋友呢。。。

作品实现的功能:

1、首页:上拉无限加载(目前没做下拉刷新),文章分类显示,点击条目进入文章详情,实现回退/Tab切换后,回到记录的滚动位置。
2、文章详情页:显示文章详情和评论,登录情况下可以收藏/取消收藏,提供回退功能。(评论点赞和回复功能暂时没有实现)
3、收藏页:显示已经收藏的文章,点击条目进入文章详情。
4、消息页:(目前没做跟消息有关的功能)。
5、我的:只提供了显示头像和退出功能。
6、登录:实现了登录功能,没有登录的情况下,进入无权限的页面会跳转到登录页面。
*、其他:首页长列表Iphone体验良好(回到顶部是缺陷),没有考虑android的情况,比如按需进行body滚动等等。
*、后期规划:不定期完善剩余功能,也有可能转战RN,下一步打算做一个思维导图,梳理一下架构思路(已完成)。
*、已知问题1:模仿iOS回到顶部功能没实现,也没做按钮式的回到顶部;
*、已知问题2:移动4G情况下,CNode的API好像被墙了,有时导致数据加载不出来。
*、已知问题3:频繁的联网/断网后,可能会出现Bug,毕竟不是线上产品,暂时不处理。


更多效果图片请到这里来看 ,掘金的图片排版我还没搞懂...

在此开放源码,提供给有兴趣一起研究的coder们,主要部分我都进行了注释。
快速实现本地dev模式运行我的源码,三步走起:

  1、选择合适的空文件夹,打开你的git bash输入 git clone git@github.com:TerryBeanX2/Webpack-React-Router-Redux-ES6.git 克隆我的仓库;2、命令行 npm install ;3、命令行 npm run dev ,浏览器访问 localhost:8888 ,F12进入移动开发模式查看 ;*、如果出现问题,尝试cnpm淘宝镜像安装。

2017.4.6更新实际项目思维导图

其实就是React+React-Router+React-Redux的架构流程图实例版

首先,我们来说为什么要用Redux


下面上本项目思维导图

希望得到你的STAR

这次很用心的做了一个作品,希望得到同仁们的肯定,
我会尽量继续更新,快来点Star吧~

React全家桶写一个CNode社区相关推荐

  1. React全家桶写一个CNode社区,奉上心得与源码

    webpack2+react+react-router+react-redux+ES6+antd-mobile版本的Cnode 苦于我就职的公司的技术栈还是ES5+jQ+handelbars, 而我一 ...

  2. react全家桶从0搭建一个完整的react项目(react-router4、redux、redux-saga)

    react全家桶从0到1(最新) 本文从零开始,逐步讲解如何用react全家桶搭建一个完整的react项目.文中针对react.webpack.babel.react-route.redux.redu ...

  3. 从零搭建React全家桶框架教程

    从零搭建React全家桶框架教程 源码地址:https://github.com/brickspert/react-family 欢迎star 提问反馈:blog 原文地址:https://githu ...

  4. react全家桶从0到1(react-router4、redux、redux-saga)

    本文从零开始,逐步讲解如何用react全家桶搭建一个完整的react项目.文中针对react.webpack.babel.react-route.redux.redux-saga的核心配置会加以讲解, ...

  5. 如何实现一个React全家桶项目(附完整教程及代码)

    文章目录 如何实现一个React全家桶项目(附完整教程) 1.相关命令: 运行项目: `yarn start` 项目打包: `yarn build` 暴露配置项: `yarn eject` 2.项目目 ...

  6. 【学习笔记】React+React全家桶学习笔记

    文章目录 1 为什么要使用React 2 React的定义 3 React的三大特性 4 React入门 4.1 hello_react 4.2 虚拟DOM的创建 4.3 JSX 4.4 模块与组件, ...

  7. 初学者的React全家桶完整实例

    概述 该项目还有些功能在开发过程中,如果您有什么需求,欢迎您与我联系.我希望能够通过这个项目对React初学者,或者Babel/webpack初学者都有一定的帮助.我在此再强调一下,在我写的这些文章末 ...

  8. React 全家桶入门教程 01

    React 全家桶入门教程 01 前面是基础课程(难度小,略过),后面是案例 目的 巩固react基础知识,查漏补缺(熟悉的部分快进) 学习相关的库的使用 https://study.163.com/ ...

  9. React全家桶(技术栈) redux 代码

    React全家桶(技术栈) redux 代码 压缩包下载 https://download.csdn.net/download/qq_42740465/87629665 README.md ## 1. ...

  10. 技术胖的2019新版React全家桶免费视频(84集)

    技术胖 2019年09月18日 阅读 29883 关注 技术胖的2019新版React全家桶免费视频(84集) 一共84集,从5月4日开始录制,到9月18日完成,5个月时间.如果是一个专业讲师,这进度 ...

最新文章

  1. 2017-2018-2 20179207 《网络攻防技术》第五周作业
  2. 傲娇Android二三事之操蛋的开发日记(第一回)
  3. react-native-sound的使用
  4. 《那些年啊,那些事——一个程序员的奋斗史》——49
  5. JS中var、let、const区别? 用3句话概括
  6. mysql for 循环删除_Java增强for循环中删除元素抛异常问题
  7. Android模拟器——Windows上比较适合王者荣耀的是腾讯手游助手
  8. JS实现图片翻书效果
  9. lora发射和接收原理_无线收发模块LoRa
  10. leetcode(300)—— Longest Increasing Subsequence(最长递增子序列)
  11. 软件测试订单测试用例,测试用例 - 进销存软件测试.doc
  12. php 公众号群发消息,PHP 微信公众号 群发文本消息
  13. 台式计算机性能与种类,最新台式机处理器性能排行榜
  14. 服装系统mysql设计_服装行业ERP系统的设计与实现-店铺模块(SSH,MySQL)(含录像)
  15. T2-小度养小猫(贪心)
  16. ilo管理脚本 hponcfg方式
  17. 在线音视频加速器终于实现了
  18. JPG图片在线翻译的操作方法
  19. 使用python玩跳一跳超详细使用教程
  20. SYN480R模块解码EV1527教程

热门文章

  1. 玩转数学答题赢大奖,福利抢先拿!
  2. JetBrain学生认证续费步骤
  3. jQWidgets 14.0 Crack
  4. [IOI2018]组合动作 题解
  5. 庄懂着色器_L19_顶点动画
  6. 本地与云服务器(阿里云)实现多客户端虚拟局域网搭建
  7. 硬件电路设计笔记-电平转换电路
  8. PET——文本分类的又一种妙解
  9. 绕过校园网Web认证
  10. rft测试软件,RFT 测试框架的核心