工作比较忙,一直没有时间总结下最近学习的一些东西,为了方便前端开发,我使用React+Redux+Router+antDesign总结了一个通用的模板,这个技术栈在前端开发者中是非常常见的。

总的来说,我这个工程十分便捷,对于初学者来说,可能包含到以下的一些知识点:

一、React-Router的使用

Router是为了方便管理组件的路径,它使用比较简单,一般定义如下就行,需要注意的是,react-router的版本有1.0-3.0,各个版本对应的API大致相似,但也有不同,我使用的是2.X的,API文档如下:

https://github.com/ReactTraining/react-router/blob/v2.8.1/docs/API.md

二、Redux和React-Redux的使用

我最初学的时候,看了网上很多Redux教程,简直是乱七八糟。为什么?不是那些人太傻比了(但也有一定的原因),而是Redux的版本发展史真的比较长。加上后来出来的React-Redux,所以各种各样的教程都有。

我这里使用的是Redux 3.5和React-Redux 4.4。这个就不放API文档了,我觉得我的demo里面写的非常清晰了。

下面以最简单的“人话”来说明下Redux的核心工作原理。

使用Redux的原因很简单,为了统一管理state。比如我的demo里的app夜间模式,可能这个参数多个component中都需要用到,所以类似这种我们必须弄成全局的。

而众所周知,React是一个通过state来render界面的框架,这就遇到一个问题,比如我要设置夜间模式,我修改普通的全局参数,并不能在修改后触发重新render,所以我们需要引入一个全局state。而Redux就是这样一个可以管理全局state的框架。

它的组成分为:

(1)store:存储全局state的对象

(2)action: 计算新state的函数(如点击开启夜间模式,darkMode参数变为true),并交给reducer

(3)reducer:根据action拿来的新参数,生成新的全局state

你肯定会说,真他妈简单。简单那就对了。网上乱七八糟的东西太多,希望我这几句话就让你明白其中的道理。

那具体如何使用Redux?

看demo就知道了,这里需要注意几点:

(1)在某个component内使用connet函数获取全局state和action中的部分,各取所需

(2)使用redux-thunk,可以进行action的同步/异步操作,因为我demo中默认使用thunk,反正异步是经常会出现的,比如我们更新用户信息,可能请求服务器需要几秒后新的用户信息才会返回,所以这个action的dispatch需要几秒后异步去触发,而默认是不支持的。

(3)存储并在app启动时初始化,我的demo中的设置夜间模式,关闭网页重新打开依旧会维持,就是我在action触发的时候做了缓存,初始化store的时候,又先从缓存取再根据这些内容,初始化store的结果。

三、antDesign的使用

demo中演示了antDesign和antDesign-mobile的两种加载(需要修改.babel)。antDesign是一款自定义component库,类似的还有amazeui,materialUI等等。antDesign-mobile就不说了,懒得评价了,那高清模式的兼容性,就像读书的时候交课堂作业一样。蚂蚁金服作为大厂,我觉得这样唐突的去发布这么一个东西实在是不合适。

antDesign相对来说成熟一点,在使用上可能需要配置一些babel等东西,这些东西,配熟练了,也就懂了。

四、webpack-dev-server和webpack的配置

webpack配置,总的来说有几块:

(1)webpack-dev-server是我推荐的一个热更新的调试组件,可以根据配置好的webpack来直接hot reload,不需要额外配其他参数。

(2)css-loadder:cssloader主要为了支持一些自定义的css写法:比如postcss,less等,demo中使用postcss去书写css,相对来说这种树形结构的css是我比较喜欢的。

(3)babel:babel是为了支持不同版本的JS语言,转换成浏览器能运行的JS。因为前端JS的版本太过零零碎碎,有时候为了支持一个小的功能,就给babel加一个小插件,以至于babel有各种乱七八糟的插件。但这种碎片化,也是JS这们开源语言能够热门、发展起来的原因。

demo地址:https://github.com/rayshen/reactjs-universal-project

ReactJS React+Redux+Router+antDesign通用高效率开发模板,夜间模式为例的更多相关文章

  1. 用react + redux + router写一个todo

    概述 最近学习redux,打算用redux + router写了一个todo.记录下来,供以后开发时参考,相信对其他人也有用. 注意: 我只实现了Footer组件的router,其它组件的实现方法是类 ...

  2. [React] react+redux+router+webpack+antd环境搭建一版

    好久之前搭建的一个react执行环境,受历史影响是webpack3.10.0和webpack-dev-server2.7.1的环境,新项目准备用webpack4重新弄弄了,旧的记录就合并发布了(在没有 ...

  3. 使用react+redux+react-redux+react-router+axios+scss技术栈从0到1开发一个applist应用

    先看效果图 github地址 github仓库 在线访问 初始化项目 #创建项目 create-react-app applist #如果没有安装create-react-app的话,先安装 npm ...

  4. webpack+react+redux+es6开发模式

    一.预备知识 node, npm, react, redux, es6, webpack 二.学习资源 ECMAScript 6入门 React和Redux的连接react-redux Redux 入 ...

  5. react+redux教程(四)undo、devtools、router

    上节课,我们介绍了一些es6的新语法:react+redux教程(三)reduce().filter().map().some().every()....展开属性 今天我们通过解读redux-undo ...

  6. angular开发者吐槽react+redux的复杂:“一个demo证明你的开发效率低下”

    曾经看到一篇文章,写的是jquery开发者吐槽angular的复杂.作为一个angular开发者,我来吐槽一下react+redux的复杂. 例子 为了让大家看得舒服,我用最简单的一个demo来展示r ...

  7. React+Redux开发实战项目【美团App】,没你想的那么难

    README.md 前言 开始学习React的时候,在网上找了一些文章,读了官网的一些文档,后来觉得React上手还是蛮简单的, 然后就在网上找了一个React实战的练手项目,个人学完之后觉得这个项目 ...

  8. webpack+react+redux+es6开发模式---续

    一.前言 之前介绍了webpack+react+redux+es6开发模式 ,这个项目对于一个独立的功能节点来说是没有问题的.假如伴随着源源不断的需求,前段项目会涌现出更多的功能节点,需要独立部署运行 ...

  9. React+Redux学习笔记:React+Redux简易开发步骤

    前言 React+Redux 分为两部分: UI组件:即React组件,也叫用户自定义UI组件,用于渲染DOM 容器组件:即Redux逻辑,处理数据和业务逻辑,支持所有Redux API,参考之前的文 ...

随机推荐

  1. Prolog 外部不能有 DOCTYPE 声明。处理资源 'http://192.168.115.152:8082/api/EmpApi.aspx' 时出错。第 3 行,位置: 11

    在Default.aspx代码中删除以下代码(其他窗口也是这样删除): <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitiona ...

  2. 删除坐标相同文本对象 按照原y坐标排序

    ;; ;;程序名称:对象水平对齐程序,并且按照竖直方向排列 ;;执行命令:tb2 ;;程序功能:将选定的对象左对齐,并且按照竖直方向排列. ;; (defun c:tb2(/ selobjs oldc ...

  3. V8编程入门

    本文档介绍了V8引擎的一些关键概念,并提供了例子hello world指引你入门. Hello World 让我们看一个Hello World的示例,它将一个字符串参数作为JavaScript语句,执 ...

  4. Oracle to_char格式化函数 显示毫秒

    racle如何显示毫秒   date类型只能精确到秒,要想精确到毫秒,需要使用timestamp类型.   应用举例:   举例1:   select to_char(systimestamp,'yy ...

  5. Nginx之RTMP

    1. RTMP协议介绍 RTMP(Real Time Messaging Protocol)实时消息传送协议是Adobe Systems公司为Flash播放器和服务器之间音频.视频和数据传输开发的私有 ...

  6. ASP.NET Zero--12.一个例子(5)商品分类管理-编辑分类

    1.添加编辑按钮 打开文件Index.js [..\MyCompanyName.AbpZeroTemplate.Web\Areas\Mpa\Views\Category\Index.js] 在acti ...

  7. Go并发编程实践

    前言 并发编程一直是Golang区别与其他语言的很大优势,也是实际工作场景中经常遇到的.近日笔者在组内分享了我们常见的并发场景,及代码示例,以期望大家能在遇到相同场景下,能快速的想到解决方案,或者是拿 ...

  8. ABP入门系列(8)——Json格式化

    ABP入门系列目录--学习Abp框架之实操演练 讲完了分页功能,这一节我们先不急着实现新的功能.来简要介绍下Abp中Json的用法.为什么要在这一节讲呢?当然是做铺垫啊,后面的系列文章会经常和Json ...

  9. linux目录下各文件夹作用

      作为一个程序员,我们难免会接触到linux系统,特别是后台程序员,因为现在项目的部署环境基本都是在linux系统上进行的,所以了解linux系统是十分重要的,虽然我接触了linux系统已经有一段时 ...

  10. shell脚本,符号

    在shell中常用的特殊符号罗列如下: # ;   ;; . , / \\ 'string'| !   $   ${}   $? $$   $* \"string\"* **   ...