android中MVC/MVP的解耦方法学习笔记

一.解耦:mvp
android中的mvc中有些人把activity认为是controller+view
这种观点我并不绝对的赞成,感觉对view的理解过于狭隘了。
我的理解是view的表现一定包括控件吧,那么textView是否属于view呢,应该属于吧,那么activity是textView的容器。
应该吧activity也算view。当然如果activity包含的逻辑多了,把他的其他逻辑算做activity也行吧。
不过这不是重点,我的重点是学习了一个这篇文章关于结构的一个实例。
解耦activity的congroller和view这里由1-6中的2-5,视乎是多余的,但这理最有价值的是,userinfo的获取放到了activity之外。
这点有什么价值呢?当然是解耦了,解谁和谁的耦呢,解controller和view的耦。
如下用一个mvc的模型理解这个流程。
首先用户发一个命令给controller:调用SampleModel的.getUserInfo(id);
controller获取数据,并将数据传递给view:相当于执行3-5的动作。
view收到数据后更新控件:setDataToview调用。
这里的巧妙在于回调的利用,view再获取mode的时候,还把都mode的装载函数传递给了contoler。
装载的过程在我 这里,但是可以把装载的这个命令交给controller,你获取到view你就调用就行。

二.解耦:mvp
android mpv解耦方式分析
关系解说
其实和前面的差不多,只不过把setDataToview变成了一个必须实现的协议。
这就是说Presenter,要利用这个借口来完成由model到view的数据传递。
这就是这里的巧妙之处,其实有些人会觉得,有没有这个对Activity的约束,好像无关紧要。
但是,你看callback里的调用。Callback的onCallback一定是要调用setDataToview。
这是Presenter能够正常工作的基础,如果没有了这个条件。
Presenter的Callback的onCallback就失去了保障。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MVCMVP、MVVM是三种常见的前端架构模式。 1. MVC(Model-View-Controller)模式 MVC模式是一种将应用程序分成三个基本部分的设计模式,分别是模型、视图和控制器。 - 模型:存储数据、定义数据操作和业务逻辑。 - 视图:呈现数据、与用户交互,接收用户输入并传递给控制器。 - 控制器:接收用户输入、处理用户请求、调用模型和视图,并将它们协调在一起。 MVC模式的优点是模块化、可扩展性好、易于维护。 2. MVP(Model-View-Presenter)模式 MVP模式是MVC模式的演化,在MVC模式,控制器扮演了连接模型和视图的角色,而MVP模式,Presenter扮演了这个角色。MVP模式将控制器拆分成Presenter和Controller两个部分。 - 模型:同MVC模式。 - 视图:同MVC模式。 - Presenter:接收用户输入、处理用户请求,调用模型和视图,并将它们协调在一起。Presenter不处理用户交互,它们通过视图来处理。 MVP模式的优点是可测试性好、可维护性好、可扩展性好。 3. MVVM(Model-View-ViewModel)模式 MVVM模式是一种将应用程序分成三个基本部分的设计模式,分别是模型、视图和视图模型。 - 模型:同MVC模式。 - 视图:同MVC模式。 - 视图模型:它是一个介于视图和模型之间的介层,可以让视图通过数据绑定的方式来操作模型。视图模型包含了视图需要的所有数据和操作,并且它负责将视图和模型解耦。 MVVM模式的优点是可测试性好、可维护性好、可扩展性好、代码量少。这种模式也可以实现双向绑定,使数据和视图自动保持同步。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值