使用原生redux模块在React组件之间实现数据共享小实例

前端之家收集整理的这篇文章主要介绍了使用原生redux模块在React组件之间实现数据共享小实例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

redux是一个提供组件之间数据共享,管理处理的模块,在react组件中使用十分广泛,如何在react组件中实现数据共享管理?

redux数据管理的基本原理

1.利用store存储数据信息,利用store.getState()得到当前的状态值
导入redux中的createStore方法,创建一个store

  1. import {createStore} from 'redux'
  2. const store = createStore()

2.state是store某一个时刻的数据值,store里面的数据变更会触发store.subscribe中回调函数,在里面设置setState引发view更新
3.定义action类型type和携带的数据,action是一个对象里面必须有type属性,它标识了action类型名称,也可以用函数生成action

  1. const action= {
  2. type: 'CHANGE',data:'data'
  3. }
  4. //another way to create a action with function
  5. function actionsCreator(obj) {
  6. return {
  7. type: 'CHANGE',name: obj.name,pass: obj.pass
  8. }
  9. }

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

  1. //redux.js
  2. import {createStore} from 'redux'
  3. const store = createStore(reducer)

2.定义某个action被dispatch后的state变化规则(这个代码必须在createStore定义store前面)
下面代码含义为如果acttion类型是CHANGE那么就返回action对象中的name和pass,借此更新state

  1. const reducer = (initialState = {
  2. name: 'mayun',pass: 'asd'
  3. },actions) => {
  4. switch (actions.type) {
  5. case 'CHANGE':
  6. return {
  7. name: actions.name,pass: actions.pass
  8. }
  9. default:
  10. return initialState
  11. }
  12. }

3.定义action对象,即什么类型的action会被分发,也可以在其中携带用户自定义的数据(我们定义的是pass和name)。这里我们用一个函数生成这个action对象,本质和直接定义action对象没啥区别

  1. function actionsCreator(obj) {
  2. return {
  3. type: 'CHANGE',pass: obj.pass
  4. }
  5. }
  6. export { actionsCreator,const store}

4.用store.subscribe()触发view更新(在子组件UShow中实现)。


  • 定义一个MyWrap组件作为容器,定义UInput UShow作为它的子组件

  1. const MyWrap=()=>(
  2. <div>
  3. <UInput></UInput>
  4. <UShow></UShow>
  5. </div>
  6. )
  7. ReactDOM.render(<MyWrap></MyWrap>,document.getElementById('example'))
  • 获取store数据。在子组件UShow 构造函数constructor中订阅state变化,设置回调函数赋值给this.state实视图更新

  1. class Ushow extends React.Component{
  2. constructor(...args){
  3. super(...args)
  4. this.state={
  5. name:'匿名',pass:'空密码'
  6. }
  7. store.subscribe(()=>{
  8. this.setState({
  9. name:store.getState().name,pass:store.getState().pass
  10. })
  11.  
  12. })
  13. }
  14. render(){
  15. return (
  16. <div>
  17. name:<span>{this.state.name}</span>
  18. &nbsp;pass:<span>{this.state.pass}</span>
  19. </div>
  20. )
  21. }
  22. }
  • view UInput中更新store。利用dispatch在UInput 中dispatch 某个action到store(数据携带在action对象的其他属性里),把数据更新从视图view传递到store

  1. class UInput extends React.Component{
  2. sure(){
  3. store.dispatch(actionsCreator({name:this.refs.name.value,pass:this.refs.pass.value}))
  4. }
  5. render(){
  6. return(
  7. <div>
  8. <div>
  9. 姓名:<input ref="name" type="text"/>
  10. 密码:<input ref="pass" type="text"/>
  11. <button onClick={this.sure.bind(this)}>登录</button>
  12. </div>
  13. </div>
  14. )
  15. }
  16. }

一定要在目录中导入redux文件import {store,actionsCreator} from '../util/redux.js'

这样就可以用原生redux实现react组件之间数据共享

猜你在找的React相关文章