详解Android中实现Redux方法

 更新时间:2018年01月05日 14:29:51   投稿:laozhang  
本篇文章给大家通过代码实例教学Android中实现Redux的方法,有需要的朋友跟着参考下吧。

Redux 是一个用于应用程序状态管理的开源JavaScript库,其核心是通过可管理和控制的状态来描述一个系统。这意味着其思想其实是可以应用于任何类型应用的开发的,包括移动应用。

Redux 架构基于一个严格的单向数据流,应用中的所有数据都是通过组件在一个方向上流动。Redux 希望确保应用的视图是根据确定的状态来呈现的。意思就是,在任何时间点,你应用的状态总是确定、有效的,并且可以转换到另一个可预测和有效的状态。而 UI 将根据所处的状态来进行呈现。

关于 Redux 在网上已经有很多相关的资料,这里就只介绍下 Redux 核心的三个组件:

1. Store:保存应用的状态并提供一些帮助方法来存取状态,分发状态以及注册监听。

2. Actions:简单说 Actions 就是事件,包含要传递给 store 的信息,表明我们希望怎样改变应用的状态。比如,定义如下的一个 action:

data class AddTodoAction(val text: String)

由 store 来进行分发:

store.dispatch(AddTodoAction("Write blog post"))

3. Reducers:进行状态的转变。类似这样:

fun reduce(oldState: AppState, action: Action) : AppState {
  return when (action) {
    is AddToDoAction -> {
      oldState.copy(todo = ...)
    }
    else -> oldState
  }
}

介绍完核心组件,下面来看一下它们是怎么组合到一起的:

Redux 的流程很简单,你的应用根据当前状态呈现 UI,用户的交互触发 action,并交给 reducer 来更新状态。

最近,作者在一个还挺大的项目上试了下 Redux 架构,所以这里就分享下从中总结的一些经验。

1. 应用里最好不要有多个 store

针对不同模块有不同的 store 似乎是个不错的主意,但从上面的图可以看到每个 store 和其数据流是一个闭环系统,这就使得不同 store 之间的状态难以同步。这样你就通常需要在一个状态的变更响应中去进行另一个 store 的 action 分发,而这很容易造成无限循环。

另一个原因是多 store 的架构是非常僵化的,难以灵活的改动。

更好的做法是维护一个包含多个子状态的全局应用状态,由一个 store 来表示:

data class AppState(val LoginState,
          val HomeScreenState,
          val GridState )

2. 保持应用的状态层级尽可能少

因为 Redux 中 state 是不可变的,因此深层次嵌套的 state 会产生很多的样板代码,并且难以更新。比如,考虑下面的一组数据模型

data class State(val sections: List<Section>)
open class Section(val articles: List<Article>)
class Home(articles: List<Article>) : Section(articles)
class Discover(articles: List<Article>) : Section(articles)
class Article

实例化和更新状态对象:

val state = State(sections = listOf(
         Home(listOf(article1, article2)),
         Discover(listOf(article1, article2))))

即使是用了 Kotlin 的 copy 机制,更新深层嵌套的属性(比如上面的 Article)也是非常单调乏味的:

val newHome = Home(listOf(newArticle, state.sections[0].articles[1]))
state.copy(sections = listOf(newHome, state.sections[1]))

3. Reducers 只是纯函数

Reduce 的作用只是处理 action 并返回新的 state 到 store 的,需要保证相同的输入总会得到一样的输出。Reduce 自身不应该有状态和执行任何额外工作,而只是做状态转换。

class Reducer {
  fun reduce(state: State, action: Action) : State {
    ...
  }
}

如果你需要响应某个 action,并执行一些操作,那应该考虑使用 Middleware。

4. 只用 Kotlin

Redux 很大部分受到 Flux 的启发,而关于 Flux 最常见的抱怨就是需要写一大堆的样板代码。而所选择的语言很大程度会决定你管理样板代码的便利性。

Kotlin 中类似 data class,when 语句之类的特性,能让你的代码清晰很多。例如,在 Reducer 中匹配 action 时,可以选择用 instanceof 方法实现。

if (action instanceof AddTodoAction) {
  return reduceAddTodoAction(oldState, action);
} else if (action instanceof RemoveTodoAction) {
  return reduceRemoveTodoAction(oldState, action);
} else if (...) {
  ...
}
return oldState;

当 action 很多时,这种写法就很痛苦了。如果用 Kotlin 就是这样的:

return when (action) {
  is AddTodoAction -> reduceAddTodoAction(oldState, action)
  is RemoveTodoAction -> reduceRemoveTodoAction(oldState, action)
  else -> oldState
}

结论

虽然,Redux 主要是被用于 Web 应用开发,但其思想我们还是可以学习并引入到 Android 中。但 Redux 也不是「银弹」,事实上也没有什么架构是,其在 Android 上的应用还很新,但我们还是很希望能看到它的逐渐成熟。

相关文章

  • Android 安全加密:数字签名和数字证书详解

    Android 安全加密:数字签名和数字证书详解

    本文主要介绍Android 安全加密数字签名和数字证书的资料,这里整理详细的资料及数字签名和数字证书应用详解,有需要的小伙伴可以参考下
    2016-09-09
  • Android仿考拉全局滑动返回及联动效果的实现方法

    Android仿考拉全局滑动返回及联动效果的实现方法

    这篇文章主要给大家介绍了关于Android仿考拉全局滑动返回及联动效果的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-08-08
  • Android RecyclerView实现拼团倒计时列表实例代码

    Android RecyclerView实现拼团倒计时列表实例代码

    这篇文章主要给大家介绍了关于Android RecyclerView实现拼团倒计时列表的相关资料,文中通过示例代码介绍的非常详细,对各位Android开发者们具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • Android编程布局(Layout)之AbsoluteLayout用法实例分析

    Android编程布局(Layout)之AbsoluteLayout用法实例分析

    这篇文章主要介绍了Android编程布局(Layout)之AbsoluteLayout用法,结合实例形式简单分析了Android绝对布局AbsoluteLayout的实现方法,需要的朋友可以参考下
    2015-12-12
  • Android日志文件的读写工具类

    Android日志文件的读写工具类

    这篇文章主要为大家详细介绍了Android日志文件的读写工具类,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • Android设计模式之单例模式实例

    Android设计模式之单例模式实例

    这篇文章主要介绍了Android设计模式之单例模式实例,单例模式是运用最广泛的设计模式之一,在应用这个模式时,单例模式的类必须保证只有一个实例存在
    2023-04-04
  • Android中用StaticLayout实现文本绘制自动换行详解

    Android中用StaticLayout实现文本绘制自动换行详解

    StaticLayout是android中处理文字换行的一个工具类,StaticLayout已经实现了文本绘制换行处理,下面这篇文章主要介绍了Android中用StaticLayout实现文本绘制自动换行的相关资料,需要的朋友可以参考。
    2017-03-03
  • Android拍照上传功能示例代码

    Android拍照上传功能示例代码

    这篇文章主要介绍了Android拍照上传功能用法,结合实例形式详细分析了Android拍照上传功能所涉及的相关知识点与功能实现技巧,需要的朋友可以参考下
    2016-08-08
  • 正确在Flutter中添加webview实现详解

    正确在Flutter中添加webview实现详解

    这篇文章主要为大家介绍了正确在Flutter中添加webview实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • Android实现Neumorphism UI控件

    Android实现Neumorphism UI控件

    大家好,本篇文章主要讲的是Android实现Neumorphism UI控件,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-02-02

最新评论