干净的架构.演示者的工作是什么?

9 android design-patterns clean-architecture android-mvp

我一直在阅读一些关于干净架构的文章,以及它如何在android中实现.我看到了显示其Android实现的示例应用程序.另外,我在Android上对Clean架构进行了很好的讨论

所以,我对大多数概念都有所了解,但我希望能够对某些事情有所了解.

根据我的理解,

  • View层是处理UI和框架相关内容的外层
  • 演示者是视图的直接通信器,它接受用户输入,并通过将其传递给用例层或交互器层来执行基于此的某些用例.
  • Interactor执行用例,将其返回给演示者发送的回调,
  • Presenter再次将此结果转换为视图可理解的数据结构(ViewModel),并将其传递回视图.

我没有列出关于内层如存储库的更多细节,因为我的问题与上述步骤有关

在这里,演示者是否只能充当UseCases和UI之间的中介,作为数据调度员?

是否仅使用视图模型来使用案例模型转换,反之亦然?

输入验证逻辑依赖于哪一层?可以在演示者里面吗?例如,如果我们采用注册过程的小用例,

一旦用户输入了详细信息并单击了注册按钮,并将数据发送给演示者,就好了

  • 如果有任何错误通知视图,Presenter将验证输入值
  • 如果值正确,则将其转换为用例模型,并执行某个用例,一旦交互器给出结果,再次转换为视图模型,将其发送到视图.

第二个问题是,谁控制导航?View或Presenter或UseCase?

谁决定下一步去哪儿?

例如 - 考虑登录过程的用例,用户将在其中输入凭据并单击"确定".

成功登录后,

  • 如果未验证用户电子邮件,请转到电子邮件验证屏幕
  • 如果用户配置文件未完成,请设置配置文件,然后仅转到主屏幕
  • 如果用户是新用户,则显示新的优惠屏幕,否则直接转到主屏幕

那么,谁负责在接下来的哪个屏幕上做出这些决定?它是演示者,它相应地决定和导航视图吗?或者是用例处理程序有责任告知演示者下一个状态是什么?

很抱歉提出这个问题的时间太长了,但我只是想详细说明我目前的理解.提前致谢

Moh*_*him 13

在这里,演示者是否只能充当UseCases和UI之间的中介,作为数据调度员?

输入验证逻辑依赖于哪一层?可以在演示者里面吗?

验证应该依赖于业务层而不是表示,是否可以在演示者内部?确定它可以,但是如果你有多个屏幕需要类似的输入,你必须在每个演示者内重复验证逻辑吗?你可以说你可以做一个基础演示者,但这不是完美的解决方案,因为演示者应该有一个目的.

第二个问题是,谁控制导航?View或Presenter或UseCase?

你认为导航是域或演示文稿或数据层的一部分,它可能与表示层有关,但你可以在表示层中创建一个小组件,它通常控制整个导航,所以你可以使用这个组件当您决定需要其他平台并将您的活动抛弃时.你可以在你提到的样本中找到这种方法.

编辑:0

如何在具有不同模型的模块之间传递数据?

你只需使用映射器,原因是使每个模块都有自己的模型或实体,因此很容易分别测试每个模块.

关于演示者和视图,假设你想要显示错误消息,演示者决定它将显示的原因,视图决定它将如何显示.

我认为用Android来理解干净的代码表示层的问题是,活动和片段不仅是视图,它们也是你的代码所处的过程和生命周期,干净的代码出现在单独的意大利面条代码上那些活动和片段.

编辑:1
添加到最后一点,现在很清楚,谷歌和那里的支持团队通过引入大量的库" 架构组件 " ,尽可能地制作活动和片段虚拟视图.我鼓励任何人检查它们,即使你正在使用MVP,你也会发现很大的好处.