随着MVP模式的日渐深入,MVP模式的应用也越来越广泛。今天我为大家介绍一下MVP设计模式。
什么是MVP
MVP是模型(Model)、视图(View)、主持人(Presenter)的缩写,分别代表项目中3个不同的模块。
模型(Model):负责处理数据的加载或者存储,比如从网络或本地数 据库获取数据等;
视图(View):负责界面数据的展示,与用户进行交互;
主持(Presenter):相当于协调者,是模型与视图之间的桥梁,将模型与视图分离开来。
如下图所示,View与Model并不直接交互,而是使用Presenter作为View与Model之间的桥梁。其中Presenter中同时持有View层以及Model层的Interface的引用,而View层持有Presenter层Interface的引用。当View层某个界面需要展示某些数据的时候,首先会调用Presenter层的某个接口,然后Presenter层会调用Model层请求数据,当Model层数据加载成功之后会调用Presenter层的回调方法通知Presenter层数据加载完毕,最后Presenter层再调用View层的接口将加载后的数据展示给用户。这就是MVP模式的整个核心过程。
MVP的应用
我们将一个注册的功能设计成MVP模式来实现,来先来看一下,MVP模式下的目录结构:
有人说这样写太麻烦了,要实现一个功能页面要多好多类。的确是这样,一个功能对应的功能类的确是多了,但是这样的结构在你的项目越来越复杂的时候,它的优势就会显现出来,这种模式将极大的缩短项目的管理和迭代开发的周期。
先来看一下RegisterActivity.xml
中的代码:
public class RegisterActivity extends AppCompatActivity implements IRegisterView,View.OnClickListener {
private EditText etUserName;
private EditText etPwd;
private Button btnRegister;
private IRegisterPresenterCompl presenter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
}
private void initView(){
etUserName = (EditText) findViewById(R.id.et_uname);
etPwd = (EditText) findViewById(R.id.et_pwd);
btnRegister = (Button) findViewById(R.id.btn_register);
btnRegister.setOnClickListener(this);
presenter = new IRegisterPresenterCompl(this);
}
@Override
public void onRegisterResult(String code, String msg) {
Toast.makeText(this,msg,Toast.LENGTH_SHORT).show();
}
@Override
public void onClick(View view) {
switch (view.getId()){
case R.id.btn_register:
Map<String,String> params = new HashMap<String,String>();
params.put("userName", TextUtils.isEmpty(etUserName.getText()) == true?"":etUserName.getText().toString());
params.put("passWord", TextUtils.isEmpty(etPwd.getText()) == true?"":etPwd.getText().toString());
presenter.doRegister(params);
break;
default:break;
}
}
}
在onCreate
方法中完成初始化工作,实现View的操作接口,内部 我们可以封装一些实际要用到的抽象方法,来完成页面业务层与展示层的交互工作
public interface IRegisterView {
public void onRegisterResult(String code,String msg);
}
同时新建Presenter
的实现类,这个实现类我们用于处理数据业务逻辑,比如数据请求、数据封装等工作,同时我们看到Presenter
的实现类IRegisterPresenterCompl
中有View的接口IRegisterView
,这样我们处理完业务逻辑就可以通过IRegisterView
来完成回调工作。
当用户点击注册按钮,代码如下:
@Override
public void onClick(View view) {
switch (view.getId()){
case R.id.btn_register:
Map<String,String> params = new HashMap<String,String>();
params.put("userName", TextUtils.isEmpty(etUserName.getText()) == true?"":etUserName.getText().toString());
params.put("passWord", TextUtils.isEmpty(etPwd.getText()) == true?"":etPwd.getText().toString());
presenter.doRegister(params);
break;
default:break;
}
}
IRegisterPresenterCompl
调用doRegister
方法获取数据,我们来看一下Presenter
及其实现类中的代码:
public interface IRegisterPresenter {
public void doRegister(Map<String,String> params);
}
public class IRegisterPresenterCompl implements IRegisterPresenter{
private IRegisterView iRegisterView;
public IRegisterPresenterCompl(IRegisterView iRegisterView){
this.iRegisterView = iRegisterView;
}
@Override
public void doRegister(Map<String, String> params) {
//接口调用
String code = "S";
String msg = "登陆成功";
iRegisterView.onRegisterResult(code,msg);
}
}
这里在doRegister
方法中接口调用成功,通过IRegisterView
回调给View层,也就是我们的RegisterActivity 。
@Override
public void onRegisterResult(String code, String msg) {
Toast.makeText(this,msg,Toast.LENGTH_SHORT).show();
}
这样我们就完成了一个简单的MVP模式功能,是不是很简单,那就动手来试试吧~
本文代码连接:https://github.com/gaoxueying/Android-HellowMvp-master