使用原生redux模块在React组件之间实现数据共享小实例
来源:互联网 发布:51铃声馆软件下载 编辑:程序博客网 时间:2024/05/17 02:58
redux是一个提供组件之间数据共享,管理处理的模块,在react组件中使用十分广泛,如何在react组件中实现数据共享管理?
https://segmentfault.com/a/1190000009400031?utm_source=tuicool&utm_medium=referral
redux数据管理的基本原理
1.利用store存储数据信息,利用store.getState()得到当前的状态值导入redux中的createStore方法,创建一个store
import {createStore} from 'redux'const store = createStore()
2.state是store某一个时刻的数据值,store里面的数据变更会触发store.subscribe中回调函数,在里面设置setState引发view更新3.定义action类型type和携带的数据,action是一个对象里面必须有type属性,它标识了action类型名称,也可以用函数生成action
const action= { type: 'CHANGE', data:'data' } //another way to create a action with function function actionsCreator(obj) { return { type: 'CHANGE', name: obj.name, pass: obj.pass }}
4.view中触发store改变。store.dispatch(action)给dispatch方法传入action来更新store中数据(dispatch是触发更新,action是定义更新类型,action类似于定义domEvent中的事件类型click 、onload、onchange······有很多类型,但是触发还需要调用store.dispatch)
5.在createStore中传入一个函数作为参数(必须),这个函数是reducer,定义dispatch某个action后state针对这个action如何更新.
reducer(initialState,action)。由于它的功能是根据初始state和action类型生成更新后的state,它接收初始initialState,action作为参数
下面是个简单的实例
功能
两个组件一个UShow 一个UInput
两者之间共享redux >store里面的数据,一个用来展示,一个用来改变store里面的数据。
方法步骤
新建一个util/redux.js
文件存放store共有数据,相关代码
1.定义store
//redux.jsimport {createStore} from 'redux'const store = createStore(reducer)
2.定义某个action被dispatch后的state变化规则(这个代码必须在createStore定义store前面)下面代码含义为如果acttion类型是CHANGE那么就返回action对象中的name和pass,借此更新state
const reducer = (initialState = { name: 'mayun', pass: 'asd'}, actions) => { switch (actions.type) { case 'CHANGE': return { name: actions.name, pass: actions.pass } default: return initialState }}
3.定义action对象,即什么类型的action会被分发,也可以在其中携带用户自定义的数据(我们定义的是pass和name)。这里我们用一个函数来生成这个action对象,本质和直接定义action对象没啥区别
function actionsCreator(obj) { return { type: 'CHANGE', name: obj.name, pass: obj.pass }}export { actionsCreator ,const store}
4.用store.subscribe()触发view更新(在子组件UShow中实现)。
定义一个MyWrap组件作为容器,定义UInput UShow作为它的子组件
const MyWrap=()=>(<div> <UInput></UInput> <UShow></UShow></div>)ReactDOM.render(<MyWrap></MyWrap>,document.getElementById('example'))
获取store数据。在子组件UShow 构造函数constructor中订阅state变化,设置回调函数赋值给this.state实视图更新
class Ushow extends React.Component{ constructor(...args){ super(...args) this.state={ name:'匿名', pass:'空密码' } store.subscribe(()=>{ this.setState({ name:store.getState().name, pass:store.getState().pass }) })}render(){ return ( <div>name:<span>{this.state.name}</span> pass:<span>{this.state.pass}</span> </div> )}}
view UInput中更新store。利用dispatch在UInput 中dispatch 某个action到store(数据携带在action对象的其他属性里),把数据更新从视图view传递到store
class UInput extends React.Component{ sure(){ store.dispatch(actionsCreator({name:this.refs.name.value,pass:this.refs.pass.value})) } render(){ return( <div> <div> 姓名:<input ref="name" type="text"/> 密码:<input ref="pass" type="text"/> <button onClick={this.sure.bind(this)}>登录</button> </div> </div> ) }}
一定要在目录中导入redux文件import {store ,actionsCreator} from '../util/redux.js'
这样就可以用原生redux实现react组件之间数据共享。
- 使用原生redux模块在React组件之间实现数据共享小实例
- 利用react-redux实现react组件数据之间数据共享
- 在不使用redux的情况下 react无关系组件之间如何通信!
- react-redux使用实例
- React Native 使用Redux全局共享state
- React Native使用原生组件
- react native使用原生模块
- react native使用原生模块
- Flux --> Redux --> Redux React 入门 基础实例使用
- Flux --> Redux --> Redux React 入门 基础实例使用
- redux在react-native上使用(五)--redux-actions使用
- redux在react-native上使用(一)--加入redux
- redux在react-native上使用(二)--加入redux-saga
- redux在react-native上使用(三)--加入redux-thunk
- redux在react-native中的使用
- 在react-native中使用redux
- 在react-native中使用redux
- 在React-Native中使用redux
- springmvc与velocity整合
- 在word中插入语法高亮且带行号的代码
- 人脸检测、人脸对齐(MTCNN方法)
- C++实验5-项目3
- AlertDialog实现单选对话框
- 使用原生redux模块在React组件之间实现数据共享小实例
- 学习淘淘商城第六十二课(添加商品同步到索引库以及消息机制测试)
- LVDS屏学习
- Direct3D基本几何体 练习
- Unable to access the IIS metabase.You do not have sufficient privilege
- 蓝桥杯训练:爆搜——天平称重
- 黑心啤酒厂
- JIRA从6.0.2升级到7.3.6
- 一些面试题备忘