ReactNative中使用Redux架构总结


Posted in Javascript onDecember 15, 2017

本文介绍了ReactNative中使用Redux架构总结,分享给大家。具体如下:

使用Redux也有一段时间了。总结一下。

为什么要使用Redux?

背景:

  1. RN的state(可变,子组件不可见)和props(不可变,子组件可见)的设计,在面对大型项目时候,容易因为不经意修改state造成状态混乱,组件渲染错误
  2. RN使用了Virtual DOM,不需要Target绑定->Action修改UI属性,只要当状态变化,render新状态下的组件,数据单向传递,而MVC的设计模式存在双向数据流。
  3. RN不易进行测试,Redux提供了非常方便的mock测试方式。

Redux开发

开发环境

  1. 安装Redux: ‘npm install ?save redux'
  2. 安装React Native和Redux绑定库:npm install ?save react-redux
  3. 安装Redux Thunk异步Action中间件:npm install ?save redux-thunk

三个原则

单一数据源

整个应用的 state 被储存在一个对象树中,对象树存在于唯一的 store 中。store中的 state 绑定到组件

State 是只读的

惟一改变 state 的方法就是触发 action。action 是一个含有 type 属性的普通JS对象,type 可以用常量表示事件。

使用纯函数来执行修改

编写 reducers 来描述对应action如何修改 state 。一般可以用 switch(action.type) 来处理,无副作用

使用

react-redux提供了connect和Provider。

1.Provider是顶层的分发点,属性就是Store,将State分发给所有被connect的组件

2.connect:接受两个参数:一个是mapStateToProps或者mapDispatchToProps,一个是要绑定的组件本身。

Store

Store 就是把 Reducer 和 action 联系到一起的对象。Store 有以下职责:

  1. 维持应用的 state?类似数据库,存储应用的所有state。
  2. 提供 getState() 方法。获取 所有的当前state;
  3. 提供 dispatch(action) 方法更新 state,相当于存入数据库,存入action来改变state。
  4. 通过 subscribe(listener) 注册监听器。

Store本质上是一个对象,它以树的形式保存了整个应用的State。并提供了一些方法。例如getState( ) 和 dispatch( )。

Redux应用只有惟一一个Store。

Store通过createStore方法来创建,根据整个应用的根Reducer的初始State。

代码如下:

import { createStore, applyMiddleware } from 'redux';
import thunk from 'redux-thunk';//异步
import reducers from './reducers';
const Store = applyMiddleware(thunk)(createStore)(reducers);
export default Store;

Reducers

Action只是描述了有事情发生了这一事实,并没有指明应用如何更新state。这是reducer要做的事情。

Reducer的本质是一个函数,并且是一个纯函数。没有任何副作用。简单来讲Reducer只负责做一件事,就是根据接收到的action和state来修改Store中的state:

(state, action) => newState

一般实现的时候,通过switch(action.type) 来判断不同的Action,default为旧state。同时可以定义初始状态。

代码:

import { combineReducers } from 'redux';
const newState = (state = {}, action = {}) => {
 switch (action.type) {
  case ActionTypes.CSTATE:
   return { ...state, ...action.state };
  case '_DPDATACHANGE_':
   return {...state, ...action.dpState};
  default:
   return state;
 }
};
//Reducer 合并
export default combineReducers({
 newState,
});

注意:返回的是新state,如果需要保留部分旧state值,使用…state(ES7的对象展开语法,对对象会浅拷贝对应属性,这里等价于Object.assign({}, state, newState)),而如果合并state的话只会合并一层,对复杂state需要手动合并。

Action

Action是一个普通JS对象,至少包括一个type属性代表事件,其他属性可以用来传递数据。实践上对一个流程定义一个函数,流程可以包括网络请求,最后返回Action,这个函数叫Action Creator。

代码:Store可以dispatch这个Action,action的type表示标识符,state是它携带的数据。

export const newState = state => {
 Store.dispatch({
  type: ActionTypes.CSTATE,
  state,
 });
};

持久化

当触发action时根据其reducer key恢复数据,然后只需要在应用启动时分发action,这也很容易抽象成可配置的拓展服务,实际上三方库redux-persist已经为我们做好了这一切。

在Action中可以代码如下:

export const getStorage = async (key) => {
 const d = await AsyncStorage.getItem(key);
 return JSON.parse(d);
};
export const setStorage = (key, value) => {
 AsyncStorage.setItem(key, JSON.stringify(value));
};

connect

通过- 提供 getState() 方法。获取 所有的当前state

通过connect,绑定需要的state以及Action Creator到你的组件的props上,这样组件就可以通过props来调用Action Creator,或者根据不同props来render()不同的组件。

代码:

mapStateToProps({ newState }) {
      const value = newState[name];//name: newState.name
      return {
       name,
      };
     },

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JQuery调用WebServices的方法和4个实例
May 06 Javascript
jquery实现模拟百分比进度条渐变效果代码
Oct 29 Javascript
jQuery中cookie插件用法实例分析
Dec 04 Javascript
js获取上传文件的绝对路径实现方法
Aug 02 Javascript
js is_valid_filename验证文件名的函数
Jul 19 Javascript
JavaScript30 一个月纯 JS 挑战中文指南(英文全集)
Jul 23 Javascript
深入理解ES6 Promise 扩展always方法
Sep 26 Javascript
通过一个简单的例子学会vuex与模块化
Nov 22 Javascript
Vue-不允许嵌套式的渲染方法
Sep 13 Javascript
微信小程序五子棋游戏的悔棋实现方法【附demo源码下载】
Feb 20 Javascript
Vue组件内部实现一个双向数据绑定的实例代码
Apr 04 Javascript
Vue调用后端java接口的实例代码
Oct 28 Javascript
Angular中使用MathJax遇到的一些问题
Dec 15 #Javascript
vue实现验证码输入框组件
Dec 14 #Javascript
基于滚动条位置判断的简单实例
Dec 14 #Javascript
微信小程序实现动态设置placeholder提示文字及按钮选中/取消状态的方法
Dec 14 #Javascript
ES6/JavaScript使用技巧分享
Dec 14 #Javascript
Django与Vue语法的冲突问题完美解决方法
Dec 14 #Javascript
浅析JS抽象工厂模式
Dec 14 #Javascript
You might like
Mysql的常用命令
2006/10/09 PHP
基于PHP服务端图片生成缩略图的方法详解
2013/06/20 PHP
ThinkPHP CURD方法之page方法详解
2014/06/18 PHP
php数组生成html下拉列表的方法
2015/07/20 PHP
如何解决phpmyadmin导入数据库文件最大限制2048KB
2015/10/09 PHP
joomla实现注册用户添加新字段的方法
2016/05/05 PHP
基于jquery用于查询操作的实现代码
2010/05/10 Javascript
jquery()函数的三种语法介绍
2013/10/09 Javascript
js生成随机数之random函数随机示例
2013/12/20 Javascript
JavaScript实现网站访问次数统计代码
2015/08/12 Javascript
jQuery+css实现的切换图片功能代码
2016/01/27 Javascript
Bootstrap每天必学之轮播(Carousel)插件
2016/04/25 Javascript
原生JS实现《别踩白块》游戏(兼容IE)
2017/02/20 Javascript
react-native-fs实现文件下载、文本存储的示例代码
2017/09/22 Javascript
jquery自定义显示消息数量
2017/12/19 jQuery
bootstrap 弹出框modal添加垂直方向滚轴效果
2018/07/09 Javascript
轻松学习JavaScript函数中的 Rest 参数
2019/05/30 Javascript
Json实现传值到后台代码实例
2020/06/30 Javascript
python通过scapy获取局域网所有主机mac地址示例
2014/05/04 Python
对Python中type打开文件的方式介绍
2018/04/28 Python
Python RabbitMQ消息队列实现rpc
2018/05/30 Python
python pandas中对Series数据进行轴向连接的实例
2018/06/08 Python
Python编程实现tail-n查看日志文件的方法
2019/07/08 Python
django迁移数据库错误问题解决
2019/07/29 Python
手把手教你Python yLab的绘制折线图的画法
2019/10/23 Python
Pytorch to(device)用法
2020/01/08 Python
python 实现socket服务端并发的四种方式
2020/12/14 Python
CSS3的transition和animation的用法实例介绍
2014/08/20 HTML / CSS
J2EE是技术还是平台还是框架
2016/08/14 面试题
自荐信格式
2013/12/01 职场文书
医院办公室主任职责
2013/12/29 职场文书
家长对孩子的评语
2014/04/18 职场文书
2014办公室副主任四风对照检查材料思想汇报
2014/09/20 职场文书
学校班子个人对照检查材料思想汇报
2014/09/27 职场文书
党的群众路线学习笔记
2014/11/06 职场文书
导游词之山海关
2019/12/10 职场文书