可能是短期内关于react的对后一篇笔记。假设读者对redux和router4有基本了解。

缘由:

现在网上很多关于react+redux的文章都是沿用传统的文件组织形式,即:

|--components

|--reducers

|--actionTypes

|--actions

|--else

这样的目录形式。这种形式的一个好处是:store中的状态一开始就是完整的,在按需加载的时候不需要特意更新root reducer和全局state树,只加载对应的视图即可。

但是,笔者在学习《深入浅出react+redux》的时候,作者提出的文件组织形式是以组件为单元组织app的文件结构,即:

|--ComponentA

  |--action

  |--reducer

  |--View

  |--index.js

|--ComponentB

  |--action

  |--reducer

  |--...

此时app的store和root reducer在一开始只有公共部分,按需加载某个组件后,再对redux store和root reducer进行更新扩充。

这种情况下,最关键的问题是:如何在每次按需加载后更新reducer和store。实践上分为两个阶段:

1.异步加载组件。组件的reducer、view、state字段作为对外暴露的接口。

2.加载完成后获取其reducer和state字段更新root reducer & redux store。

《深入浅出》中作者给的方法是:

1.用webpack的require.ensure分片组件,实现异步加载。

2.借助store enhancer拓展一个store.reset方法,将新组件的reducer和state字段传进去,完成更新。

然而现在要使用router4,怎么解决上面问题呢?

我目前的方案是:

1.异步加载使用Bundle组件(下面会给出其代码)。

2.刷新store和root reducer仍然使用《深入浅出》作者给出的reset方法。

----------------------------------------------------------分割-----------------------------------------------

我们现在已经会使用redux管理app状态。将state提取到全局store,并经由disptach方法派发action给root reducer 生成新的store state,而组件本身以观察者监听state变化。

router4遵循组件即路由的思想,url匹配时由Route标签渲染我们的组件。所以本质上<Route>也是视图。与Redux毫无冲突。

它们一个限制了我们app的数据流,一个控制我们视图的跳转。

由于react-redux提供的Provider组件必须放到应用的最顶层以实现全局访问store,所以项目的最基本骨架是:

|--Provider
|--App
|--Router
|--RouteA
|--RouteA child
|--RouteB
//...

在Router4中,我们往往用到的是Bundle组件来异步加载组件,我对它进行一些改写,以适应“按组件组织文件”的方式:

 import React from 'react';
import PropTypes from 'prop-types';
import {
combineReducers
} from 'redux';
import store from './Store.js';
class Bundle extends React.Component {
constructor(props) {
super(props);
this.state = {
mod: null
};
this.page=null;
}
componentWillMount() {
// 加载初始状态
this.load(this.props);
} componentWillReceiveProps(nextProps) {
if (nextProps.load !== this.props.load) {
this.load(nextProps);
}
} load(props) {
// 重置状态
this.setState({
mod: null
});
// 传入组件的组件
props.load().then((mod) => {
//...
this.page=mod.Page;
let {Page,stateKey,reducer,initialState} = mod;
let state=store.getState(); store.reset(combineReducers({...store._reducers,[stateKey]:reducer}),{...state,[stateKey]:initialState}); this.setState({
// handle both es imports and cjs
mod: mod.Page.default ? mod.Page.default : mod
});
});
} render() {
// if state mode not undefined,The container will render children
return this.state.mod ? this.props.children(this.page) : '加载中,请稍候...';
}
} Bundle.propTypes = {
load: PropTypes.func,
children: PropTypes.func
}; export default Bundle;

一个最基本的项目用到的依赖:

react:

提供了React、Component 帮助我们搭建视图层。

redux:

combineReducers帮我们生成Root Reducer

createStore帮我们创建全局的store管理app状态。

applyMiddleware 让我们调用中间件,增强dispatch方法

compose帮我们组装store enhancer

react-redux:

Provider:让我们可以全局访问store

connect:生成容器组件和store通信

router4:

Router、Route、Link等实现项目页面路由

Bundle组件:

配合Router4实现按需加载(用到import语法)

工具明确了之后,我们开始构建应用。

0.创建项目目录:全局的store.js、index.js、enhancer文件夹、组件文件夹等

1.设计state树

2.创建各个组件,写它的actionType、actionCreator、reducer,View、stateKey,在组件文件夹下index.js中引入,并将actionCreator、reducer、stateKey等导出。

3.将公共部分的reducer引入root reducer文件中

4.实现store,引入enhancer/reset.js,让其具备reset方法,以便按需加载时刷新reducer和状态。

5.在index.js 和 App.js中搭建顶层结构,组织各个组件,设计各个页面的路由。

//...

测试。

build。

React:redux+router4搭建应用骨架的更多相关文章

  1. react+redux项目搭建及示例

    React + Redux示例,实现商品增删改 目录结构 1.项目搭建 1.1 使用create-react-app react_redux创建项目 1.2 安装使用redux需要的依赖 npm in ...

  2. node.js+ react + redux 环境搭建

    1.安装node.js 2. yarn init: 初始化,主要包含以下条目 name: 项目名 version: 版本号 description: 项目简要描述 entry point: 文件入口, ...

  3. 用react+redux+webpack搭建项目一些疑惑

    --save-dev开发用 例如:webpack --save开发和发布用 例如:react

  4. react+redux+generation-modation脚手架搭建一个todolist

    TodoList 1. 编写actions.js 2. 分析state 试着拆分成多个reducer 3. 了解store 4. 了解redux数据流生命周期 5. 分析容器组件和展示组件 搞清楚,数 ...

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

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

  6. webpack+react+redux+es6

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

  7. React+Redux实现追书神器网页版

    引言 由于现在做的react-native项目没有使用到redux等框架,写了一段时间想深入学习react,有个想法想做个demo练手下,那时候其实还没想好要做哪一个类型的,也看了些动漫的,小说阅读, ...

  8. 使用React全家桶搭建一个后台管理系统

    引子 学生时代为了掌握某个知识点会不断地做习题,做总结,步入岗位之后何尝不是一样呢?做业务就如同做习题,如果‘课后’适当地进行总结,必然更快地提升自己的水平. 由于公司采用的react+node的技术 ...

  9. react + redux 完整的项目,同时写一下个人感悟

    先附上项目源码地址和原文章地址:https://github.com/bailicangd... 做React需要会什么? react的功能其实很单一,主要负责渲染的功能,现有的框架,比如angula ...

随机推荐

  1. HDFS一些基本操作方法

    启动hadoop cd /usr/local/hadoop ./sbin/start-dfs.sh 在浏览器中打开localhost:50070 找到 进入  操作 1)新建文件夹      在根目录 ...

  2. JavaScript--'data-'的用法(1)

    HTML5为我们提供了一个强大的功能,前段也也能实现后台数据库的效果,例如data-xxx <a href="#myModal" data-industry_id=" ...

  3. bootstrap4中使用fontawesome5.6.3

    先下载fontawesome5.6.3,选择free for web,下载完解压,丢在资源目录下 <form action=""> <div class=&quo ...

  4. 一篇文章让你彻底弄懂SSL/TLS协议

    目录 SSL/TLS的应用 TLS协议的架构 握手协议 主密码和预备主密码 TLS记录协议 一篇文章让你彻底弄懂SSL/TLS协议 SSL/TLS是一种密码通信框架,他是世界上使用最广泛的密码通信方法 ...

  5. Spring MVC 中的http Caching

    文章目录 过期时间 Last-Modified ETag Spring ETag filter Spring MVC 中的http Caching Cache 是HTTP协议中的一个非常重要的功能,使 ...

  6. POJ - 2387 Til the Cows Come Home (最短路入门)

    Bessie is out in the field and wants to get back to the barn to get as much sleep as possible before ...

  7. UVA-2【NOI2014】起床困难综合症

    #2. [NOI2014]起床困难综合症 21 世纪,许多人得了一种奇怪的病:起床困难综合症,其临床表现为:起床难,起床后精神不佳.作为一名青春阳光好少年,atm 一直坚持与起床困难综合症作斗争.通过 ...

  8. P3842 [TJOI2007]线段

    最近多刷些dp,觉得这个算不上蓝题   在一个\(n\times n\)的平面上,在每一行中有一条线段,第\(i\)行的线段的左端点是\((i, L_i)\),右端点是\((i, R_i)\),其中\ ...

  9. 题目分享F 二代目

    题意:T个点R种双向边,P种单向边,求点S到每个点的最短距离 分析:(这再看不出来是spfa就该**了) 首先,这题能否用spfa就看他是否有负环呗,显然,双向边的权值非负,单向边还有个啥政策,总之显 ...

  10. 使用Codemirror打造Markdown编辑器

    前几天突然想给自己的在线编译器加一个Markdown编辑功能,于是花了两三天敲敲打打初步实现了这个功能. 一个Markdown编辑器需要有如下常用功能: 粗体 斜体 中划线 标题 链接 图片 引用 代 ...