Android中的MVP,从这里开始写笔记!
这段时间因为公司要搭建MVP项目,所以自己也赶紧看了几篇文章,自己总结一下自己的理解。
首先,先上图- -
多的不扯,MVP中讲xml与Activity合称为View层, 然后多个P层,是为了让Activity不参与业务逻辑的处理。
因为我是这么打算的,retrofit+rxjava来封装网络框架(也是这几天才学的,之前用okgo),封装后,将它当做Model层。
然后看看项目结构:
图上,view分为Activity,Fragment,还有一个view接口。然后net是封住好的rxjava+retrofit 网络请求框架
接下来写一个简单的引导页面来实现一下自己所理解的MVP:
首先,我定义了一个View接口,这个接口是用来获取控件和上下文的,当然,一些刷新UI的方法也是要写在这里面的,因为引导页比较简单,就没有那些胡里花哨的东西。看图:
第二步:让与之相关的Activity实现这个接口,并做处理,这里的动作也很简单,就直接return控件回去就好啦,看图
因为引导页没涉及到网络请求的数据,所以这里就没有Model层啦,接下来看看Presenter层,
首先通过构造把View接口传进来,获取到那些控件,看图:
拿到控件之后我们就可以为所欲为的做逻辑处理啦,定义了三个方法,页面跳转什么的,viewpager的设置,滑动的监听逻辑等,看图啦:
啊哈哈哈哈,最后一步来了,最后也超简单的,就在Activity里面获取到Presenter层的实例,然后调用方法,看图看图:
是不是好简单,这就是我个人所理解的MVP,网上大神各种写法都不一致。
我是个应届生,目前就职于一家很一般的公司,不是什么大公司,水平有限,所以大神就勿喷了,而且主要是想做笔记给自己看看,总结一下自己所学的东西。关于MVP,最重要的是不让Activity处理业务逻辑。这边如果是有网络请求的,rxjava+retrofit的封装当做Model层,然后在P层调用封装好的retrofit接口,拿到数据后,开一个CallBack给Activity,为什么还要开CallBack呢,直接在Activity拿到数据不就好了吗,因为这些数据可能有些要做处理,如果在Activity做处理的话,就违背了MVP的原则了,所以我开个CallBack回调给Activity,保证Activity拿到的数据是最后不用处理的。当然,这只是个人的见解,哈哈哈哈~第一次写博客。