React-Native-Redux数据和事件在组件间通信

React-Native 中数据和事件在组件间通信

React-Native中没有原生的block和代理,所以RN中数据的显示和事件绑定需要在组件间通信,需要一层层的传递,如果层级太深,导致传递的逻辑不太容易维护和管理,业务和数据掺杂一起,数据的改变可能导致render的刷新频率过高,影响性能,所以业界因为React的数据管理redux,通过store去管理数据和事件。

假如我们要实现一个计数器的小功能

Counter.png
通常数据和事件的通信
  1. 在组件中实现加减重置逻辑
  2. 实现回调方法(带参数)
import React from 'react';
import {View, Button, Text} from 'react-native';
import PropTypes from 'prop-types';

export default class CommonCounter extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      count: 0,
    };
  }

  decrement() {
    this.setState({
      count: this.state.count - 1,
    });
    this.props.updateCurrentCount(this.state.count - 1);
  }
  increment() {
    this.setState({
      count: this.state.count + 1,
    });
    this.props.updateCurrentCount(this.state.count + 1);
  }
  reset() {
    this.setState({
      count: 0,
    });
    this.props.updateCurrentCount(0);
  }

  render() {
    return (
      <View
        style={{
          flexDirection: 'row',
          justifyContent: 'center',
          alignItems: 'center',
        }}>
        <Button onPress={this.decrement.bind(this)} title={'-'} />
        <Text>{this.state.count}</Text>
        <Button onPress={this.increment.bind(this)} title={'+'} />
        <Button onPress={this.reset.bind(this)} title={'reset'} />
      </View>
    );
  }
}

CommonCounter.propTypes = {
  updateCurrentCount: PropTypes.func,
};

在界面中操作组件

<!--在界面中操作Counter组件-->
render() {
    return (
         <CommonCounter updateCurrentCount={this.updateCurrentCount.bind(this)}/>
    );
  }
 
  <!--实现回调方法-->
updateCurrentCount(count) {
    console.log(count);
  }

Redux实现
  1. 项目中需要导入redux,react-redux
  2. 需要创建action,redux
  3. 实现connect,高级组件connect会对数据和事件进行处理,传递给store

创建action

export const increment = () => ({
  type: 'INC',
});

export const decrement = () => ({
  type: 'DEC',
});

export const reset = () => ({
  type: 'RES',
});

创建redux,绑定到高级组件connect上


import React from 'react';
import {connect} from 'react-redux';
import {increment, decrement, reset} from './ReduxAction';
import {Button, View, Text} from 'react-native';

const mapStateToProps = (state) => ({
  count: state.count,
});

const mapDispatchToProps = {
  decrement,
  increment,
  reset,
};

function Counter({count, increment, decrement, reset}) {
  return (
    <View
      style={{
        flexDirection: 'row',
        justifyContent: 'center',
        alignItems: 'center',
      }}>
      <Button onPress={decrement} title="-" />
      <Text>{count}</Text>
      <Button onPress={increment} title={'+'} />
      <Button onPress={reset} title={'reset'} />
    </View>
  );
}

export default connect(mapStateToProps, mapDispatchToProps)(Counter);

store会对数据和事件统一分配和处理

  1. 需要导入{Provider},{creatStore}
  2. 创建store
import {Provider} from 'react-redux';
import {createStore} from 'redux';

当store下的组件发生变化时,会更新redux,action,去做一些相应的处理


render() {
    return (
      <Provider store={store}>
        <Counter />
      </Provider>
    );
  }
  
  const initialState = {
  count: 0,
};

function reducer(state = initialState, action) {
  let newCount = 0;
  switch (action.type) {
    case 'INC':
      newCount = state.count + 1;
      break;
    case 'DEC':
      newCount = state.count - 1;
      break;
    case 'RES':
      newCount = 0;
      break;
    default:
      return state;
  }
  console.log(newCount);
  return {...state, count: newCount};
}

const store = createStore(reducer);

更多Redux的使用,我会在接下来整理出具体的文档出来,供React-Native使用者更加便捷的操作数据和事件,做到业务数据分离,降低耦合,降低开发难度,具体代码我已上传GitHub

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335