最近利用业余时间来深入学习MVP模式,我把自己对MVP模式的理解分享给大家,希望能给你理解MVP模式提供帮助。
相信大家已经对MVC模式再熟悉不过了。如果你还对MVC模式不熟悉的话,建议把MVC理解透之后再往下看。因为MVP模式可以说是MVC模式在Android开发上演变过来的。
MVC全称为Model-View-Controller,是模型(Model)-视图(View)-控制器(Controller)的缩写。MVC开始存在于桌面程序中,M是指业务模型,V是指用户界面,C则是控制器,使用MVC的目的是将M和V的实现代码分离,以便后续程序的维护以及更新。
对于原生的Android项目而言:
我们经常在Activity或者Fragment中执行控件的初始化操作以及处理控件的点击事件,也就是执行findViewById()方法和setOnClickListener()方法。这就导致Activity(Fragment)不是单纯的Controller。随着界面以及其逻辑的复杂度不断提升,Activity(Fragment)的职责不断增加,这会使得Activity(Fragment)变得十分臃肿。想想看,如果Activity或者Fragment代码上千行的话,别说继续增加新功能,连维护都觉得有点恶心。为了给Activity(Fragment)减负,MVP模式就此孕育而生。
MVC全称为Model-View-Presenter, 是模型(Model)-视图(View)-表示(Presenter)的缩写。Presenter充当Model和View之间交互的桥梁,负责将对应的Model和View组合到一起。
对于原生的Android项目而言:
以antoniolg大神的androidmvp开源项目作为栗子讲解 在项目目录中一共有十个类,我就以login包作为突破点阐述MVP实现思路。
View层中有LoginActivity和LoginView这两个类。LoginActivity是登录界面类;而LoginView是个接口类,根据LoginPresenterImpl类对数据的处理结果进行UI交互。
1)LoginView主要包含更新UI的方法
,让LoginPresenterImpl类持有其引用。这样LoginPresenterImpl类就可以通过LoginView来更新UI。具体代码如下:
2)LoginActivity类主要工作是初始化UI和实现更新UI的方法
,代码如下:
Presenter层中有LoginPresenterImpl和LoginPresenter这两个类。LoginPresenterImpl是LoginPresenter接口的实现类;LoginPresenter同样也是个接口类。
1)LoginPresenter包含验证登录信息和销毁对象的方法
。LoginActivity类可以通过其将数据传递给LoginPresenterImpl类。具体代码如下:
2)LoginPresenterImpl类实现验证登录信息以及销毁对象的方法
,但是它内部验证信息还是LoginInteractorImpl类来实现的。具体代码如下:
model层的类分别是:LoginInteractor和LoginInteractorImpl。LoginInteractor也是个接口。LoginInteractorImpl类实现了LoginInteractor中的方法 1)LoginInteractor中的方法是真正处理数据,即验证信息是否符合标准。LoginInteractor会把LoginInteractorImpl处理数据的结果返回给LoginPresenterImpl。
2)LoginInteractorImpl对登录信息进行验证,就是进行判空操作。如果需要请求服务器来判断登录是否成功,那么这里也是进行网络操作。
如果你能把上面的代码拿下,那么你对MVP模式已经理解差不多了。你自己再把剩余的代码看一遍,举一反三,就可以打通了MVP这道脉。
响应式编程库RxJava已经火的不得了,其好处是很大幅度的降低代码量。MVP和RxJava可以无缝对接,两者算是绝配。
本文的demo:https://github.com/antoniolg/androidmvp 谷歌官方MVP实例代码: 1、对应分支todo-mvp:https://github.com/googlesamples/android-architecture 2、对应分支todo-mvp-rxjava: https://github.com/googlesamples/android-architecture/tree/todo-mvp-rxjava
作者:猴哥,公众号:极客猴。爱好读书,喜欢钻研技术,梦想成为文艺青年的IT Boy。
- END -