Android项目架构1 - TODO-MVP(译)

作者: 热血沸腾 | 来源:发表于2017-02-07 11:17 被阅读133次

    Github官方地址      todo‑mvp 深入浅出学习 

    概要

    该例是其他衍生例子的基础。该例不使用Android framework而简单实现了 Model-View-Presenter 模式。本地和远程数据源仓库是通过手工依赖而注入的。异步任务通过操作回调

    架构示意图

    注意:

    在MVP的上下文中,叫做"view"的应该重新解读:

    1. "android.view.View"包下的类会被解读为View

    2. 在MVP中一个从Presenter接受命令的View被简单的叫做“View”

    Fragments

    使用Fragments有两个原因:

    1. Activity与Fragment的友好分离非常适合实现MVP:Activity对于创建、联系View和Presenter是总的控制器

    2.平板的多View多屏幕利用的Fragment框架的优势来布局的

    关键概念

    app中有四个功能

    1. Tasks

    2. TaskDetail

    3. AddEditTask

    4. Statistics

    每个功能都有:

    1.  View和Presenter之间具有协议(接口实现)

    2. 一个负责创建Fragment和Presenter的Activity

    3. 实现了View接口的Fragment

    4.实现了Presenter接口的Presenter

    一般来讲,业务逻辑是存在于Presenter中的,并且通过Android UI 来操作一些动作。View中几乎没有逻辑: 它接受Presenter的命令而使得UI发生变化,并且监听用户动作回馈给Presenter。View与Presenter之间的的协议通常是通过interface来定义的。

    依赖

    Android 原生库(com.android.support.*)

    Android 测试库(Espresso, AndroidJUnitRunner…)

    Mockito  测试库

    Guava (null checking)  基于1.6的扩展类工具集合

    特征

    复杂性-可理解性

    使用第三方框架/依赖/工具? 没有

    概念复杂性

    低,因为它是Android上纯净的MVP实现

    测试性

    单元测试

    高,Presenter 和 数据源都是独立单元

    UI测试

    高,允许fake数据注入到fake模型中  (fake 有点像模拟,伪造的意思)

    代码量

    相比于传统的工程

    与没有架构的传统项目比,本例引入了额外的类、接口、Presenter、仓库等。因此,MVP架构中代码的行数和类数量会更多些。

    代码量示意图

    可维护性

    易于修改或添加功能

    学习成本

    低。功能很容易找到,责任明确。开发人员不需要熟悉任何外部依赖项来处理项目。

    相关文章

      网友评论

        本文标题:Android项目架构1 - TODO-MVP(译)

        本文链接:https://www.haomeiwen.com/subject/mvkpittx.html