一、概念:             http://caibaojian.com/react/redux-basic.html   或  https://www.cnblogs.com/maopixin/p/9989236.html  或  https://www.jianshu.com/p/7a867be0594a(推荐)

  1、redux 是独立于react的,其他的框架也是可以使用的。

二、安装 redux模块:

npm install --save redux react-redux redux-thunk
npm install --save-dev redux-logger

  说明: redux 和 react-redux 是必须的 redux-thunk可以帮你实现异步action。redux-logger可以实现监测redux的变化,

  Redux

    状态管理工具,与React没有任何关系,其他UI框架也可以使用Redux

  react-redux

    React插件,作用:方便在React项目中使用Redux。(react-redux 和 redux 有版本兼容性的问题。测试有效的版本 redux@4.0.1react-redux@5.0.7redux-thunk@2.3.0

  react-thunk

    中间件,作用:支持异步action

三、使用:单纯 使用 redux,不使用  react-redux,等其他的模块。   https://blog.csdn.net/weixin_43221330/article/details/88356640(只有写了 读取redux的数据) 或  https://www.cnblogs.com/yuyujuan/p/11355057.html(推荐,包括读取和修改redux的数据)

  1、创建 store 库:
import { createStore } from 'redux';
import reducers from './reducers.js' // reducers 是一个函数,返回一个最新的 state。调用这个函数时,会传入 两个参数:state和action。其中state指的是原仓库的状态, action指的是新传递的状态 const store = createStore(reducers); // 程序调用dispatch方法,就会触发 reducers 函数,修改state值。 创建时就会调用 reducers 函数。
export default store;

  2、创建reducer:  调用 store 的 dispatch方法,就会触发 reducers 函数,修改state值。 创建时就会调用 reducers 函数。

   页面调用 dispatch 方法,怎么赋值给 store 的 state,自己可以在 reducers 函数中自由发挥。

const defaultState  = {
inputValue: 'fine'
//默认state数据
} export default (state = defaultState , action)=>{
switch (action.type){
case 'inputValue':
state.inputValue = action.value
break;
default:
break;
}
return state;
}

  3、组件获得store中的数据 :

this.state = store.getState();

  4、组件 改变 store 中的数据(action):

     注意:action 必须是一个对象,且有一个 type 字段。

        const action = {
type:'inputValue',
value:'1234567'
}
setTimeout(() => {
store.dispatch(action)
},10000)

  5、store 数据更新了,需要在 组件的constructor 生命周期中订阅redux的状态 ,才能同步更新。(订阅的API方法  subscribe)

    constructor(props){
this.state = store.getState();
store.subscribe(this.change); change是一个函数,当store改变,就会订阅发布,执行 subscribe 内的 函数。在 change 函数里面,在修改本地的 state ,更新视图
}

  6、上面知道怎么用,现在 可以看下 redux 的设计原理了:        https://www.jianshu.com/p/e984206553c2

四、Redux + React-Redux 的使用:  https://www.jianshu.com/p/ad7eddb23d66(最后的 简单计数器的代码有效)  或 https://www.php.cn/js-tutorial-403709.html(推荐,把入口文件,和 页面组件分开的)
   1、<Provider> 组件:   能够使 里面的 组件都能 访问到Redux store中的数据。【根组件外面包了一层Provider组件,所有子组件就都可以拿到 store中的数据了。】
    注意:当前组件中使用 <Provider> ,使用store数据是无效的。<Provider> 必须是在 使用store 组件的父级组件上使用。所以这个一般是放在跟组件上的。
   2、connect():connect方法使你可以从Redux store中读取数据(以及当store更新后,重新读取数据)。如:
//  将state映射到Counter组件的props
function mapStateToProps(state) { // connect 第一个函数参数会把 store 的 state 作为参数传入,方便这个函数内 获取 state 中 的数据,映射到当前组件的props中。方便组件 通过 props 获取 store的数据。
return {
value: state.count
}
} // 将action映射到Counter组件的props
function mapDispatchToProps(dispatch) { // connect 第二个函数参数会把 store 的 dispatch 作为参数传入,方便这个函数内 获取 store的dispatch方法 ,映射到当前组件的props中。方便组件通过props的方法修改 store 的数据。
return {
onIncreaseClick: () => dispatch(increaseAction)
}
} // 传入上面两个函数参数,将Counter组件变为App组件。 Counter组件 拷贝一份,通过 mapStateToProps、mapDispatchToProps函数,给 拷贝的组件传入 props 属性 和方法。【这里是给组件的props传入了 props.value 属性 和 props.onIncreaseClick 方法 】
const App = connect(
mapStateToProps,
mapDispatchToProps
)(Counter)
     思考:组件使用connect 就相当于在 父 子组件间加了一层 功能组件。不用store的组件,可以不用加这一层功能组件(即不用 connect 处理这个组件)。
   3、mapStateToProps(state):建立一个从(外部的)state对象到(UI 组件的)props对象的映射关系。
   4、mapDispatchToProps(dispatch):建立 UI 组件的参数到store.dispatch方法的映射。      这里 函数内的dispatch 每执行一次,就会触发 mapStateToProps 函数 执行,从而引起 组件的 更新。
 
 
五、 
 

dva:    https://dvajs.com/guide/  (在使用  antd pro 框架开发后管系统时,里面带了dva。所以这里介绍下)

 一、概念:
  1、dva 首先是一个基于 redux 和 redux-saga 的数据流方案
 
二、使用介绍: (这里,只是 介绍下 ,在项目中 碰到的 APi ,其它的不讲解)
  1、connect 方法: connect 是一个函数,绑定 State 到 View。
  2、dispatch 方法:dispatch 是一个函数方法,用来将 Action 发送给 State。
            被 connect 的 Component 会自动在 props 中拥有 dispatch 方法。
  3、Reducer:是 Action 处理器,用来处理同步操作,可以看做是 state 的计算器。(这个和原生 redux 中的reducer 功能类似)
  4、Effect:    是 Action 处理器,处理异步动作,基于 Redux-saga 实现。

react教程 — redux的更多相关文章

  1. 【前端】react and redux教程学习实践,浅显易懂的实践学习方法。

    前言 前几天,我在博文[前端]一步一步使用webpack+react+scss脚手架重构项目 中搭建了一个react开发环境.然而在实际的开发过程中,或者是在对源码的理解中,感受到react中用的最多 ...

  2. 【前端,干货】react and redux教程学习实践(二)。

    前言 这篇博文接 [前端]react and redux教程学习实践,浅显易懂的实践学习方法. ,上一篇简略的做了一个redux的初级demo,今天深入的学习了一些新的.有用的,可以在生产项目中使用的 ...

  3. 实例讲解react+react-router+redux

    前言 总括: 本文采用react+redux+react-router+less+es6+webpack,以实现一个简易备忘录(todolist)为例尽可能全面的讲述使用react全家桶实现一个完整应 ...

  4. React 与 Redux 在生产环境中的实践总结

    React 与 Redux 在生产环境中的实践总结 前段时间使用 React 与 Redux 重构了我们360netlab 的 开放数据平台.现将其中一些技术实践经验总结如下: Universal 渲 ...

  5. React、Redux 和 Bootstrap

    使用 React.Redux 和 Bootstrap 实现 Alert 今天,我们来学习使用 React.Redux 和 Bootstrap 实现Alert. 例子 这个例子实现了弹出不同类型信息的功 ...

  6. react native redux 草稿

    Provider > Provider > 使组件层级中的 方法都能够获得 Redux store.正常情况下,你的根组件应该嵌套在 Provider 中才能使用 方法. 如果你真的不想把 ...

  7. 基于 React.js + Redux + Bootstrap 的 Ruby China 示例 (转)

    一直学 REACT + METEOR 但路由部分有点问题,参考一下:基于 React.js + Redux + Bootstrap 的 Ruby China 示例 http://react-china ...

  8. 基于react+react-router+redux+socket.io+koa开发一个聊天室

    最近练手开发了一个项目,是一个聊天室应用.项目虽不大,但是使用到了react, react-router, redux, socket.io,后端开发使用了koa,算是一个比较综合性的案例,很多概念和 ...

  9. 最新的chart 聊天功能( webpack2 + react + router + redux + scss + nodejs + express + mysql + es6/7)

    请表明转载链接: 我是一个喜欢捣腾的人,没事总喜欢学点新东西,可能现在用不到,但是不保证下一刻用不到. 我一直从事的是依赖angular.js 的web开发,但是我怎么能一直用它呢?看看最近火的一塌糊 ...

随机推荐

  1. Nginx 模块 - ngx_core_module

    原文地址 示例配置 指令 accept_mutex accept_mutex_delay daemon debug_connection debug_points env error_log even ...

  2. vue封装分页组件

    element提供的分页是已经封装好的组件,在这里再次封装是为了避免每个用到分页的页面点击跳转时都要写一遍跳转请求 分页组件 <!--分页组件--> <template> &l ...

  3. Recurrent Neural Network(2):BPTT and Long-term Dependencies

    在RNN(1)中,我们将带有Reccurent Connection的node依照时间维度展开成了如下的形式: 在每个时刻t=0,1,2,3,...,神经网络的输出都会产生error:E0,E1,E2 ...

  4. 应用安全-工具使用-Burpsuite

    A cheat sheet for PortSwigger Burp Suite application security testing framework. Send to Repeater Ct ...

  5. Codeforces Round #410 (Div. 2)B. Mike and strings(暴力)

    传送门 Description Mike has n strings s1, s2, ..., sn each consisting of lowercase English letters. In ...

  6. php用什么软件编程

    准备好好学习学习PHP了吗?那么你首先应该考虑用什么开发工具(IDE).市面上有很多这类工具,收费的有,免费的也有,选择起来并不轻松. 如果你说PHP编程用基础的文本编辑软件就可以了,比如用记事本.是 ...

  7. java_第一年_JDBC(3)

    事务 我们在通过JDBC连接数据库并开始交互时,默认情况下是自动提交的,有时由于为了保持业务流程的完整性.提高性能或是使用分布式事务,需要启动支持事务,此时的方法是调用Connection对象的set ...

  8. BZOJ 1937 (luogu 4412) (KM+LCA)

    题面 传送门 分析 根据贪心的思想我们得到几条性质: 1.生成树上的边权减小,非树边的边权增加 2.每条边最多被修改一次 设改变量的绝对值为d 对于一条非树边\(j:(u,v)\),树上u->v ...

  9. Day4 --- Python中的控制结构(if, for, while, try...expect..)

    if for while 可以参考 : https://www.cnblogs.com/HYLering/p/10051906.html try  是异常处理里面的 可以参考 : https://ww ...

  10. 分布式自增ID算法-Snowflake详解

    1.Snowflake简介 互联网快速发展的今天,分布式应用系统已经见怪不怪,在分布式系统中,我们需要各种各样的ID,既然是ID那么必然是要保证全局唯一,除此之外,不同当业务还需要不同的特性,比如像并 ...