android面向holder编程,再度封装代码
来源:互联网 发布:软件 评职称 编辑:程序博客网 时间:2024/05/23 15:06
概述
在我们实际开发过程中,当我们软件的功能做得多的时候,这个时候我们的代码量也就越来越大了,如果我们不把代码进行封装,不仅让我们开发的时候变得困难,而且不利于维护,特别是团队开发的时候,如果我们一个Activity就几百行,当然几百行也算是少的了,甚至可能上千行。这个时候如果让你看几千行的代码,你是不是觉得好费劲呢,而且开发起来也变得困难了。
面向holder编程思想其实很简单,就是简单的把一个大的复杂的功能或者页面分成几个小的功能分别去实现,下面我们看一张图片来看看面向holder编程思想
这个是我从和阅读上面截的一张图,我们来分析一下要实现这样一个相对复杂的界面功能,我们可以怎么做。下面我们来对这个界面进行划分一下
如果你觉得这种界面功能不复杂的话,你就可以不划分,直接写在个布局里面,然后在一个Activity中完成相应的界面功能,当你的activity里面的代码就大了好多,你也可以有其他的划分方法。
当我们把上面的复杂界面划分好了之后我们可以在这个activity的布局文件里面只要写上4个FrameLayout或者RelativeLayout,然后在代码中实例化它们,之后开始每个小功能在holder里面写了
在holder里面我们可以这样写
import android.content.Context;import android.view.View;public class Holder { private View rootView; private Context ct; public Holder(Context ct) { this.ct = ct; init(); initView(); initData(); } /** * 可以在这里完成一些初始化的操作,这些操作可以在布局没有实例好之前初始化 */ private void init() { } /** * 在这里面实例化布局相关的组件 */ private void initView() { } /** * 在这里可以为相应的组件添加事件,初始化状态,或者联网请求数据 */ private void initData() { } /** * 得到该holder维护的view * @return 该holder维护视图的根布局 */ public View getRootView() { return rootView; }}
完成了上面的简单的holder模型之后,之后在initView和initData方法完成的操作就和在activity或者fragment中的操作相同了
在此之后我们只要在activity中创建该Holder,然后在activity中为之前写的FrameLayout或者RelativeLayout调用addView
方法把从holder.getRootView()
得到的view
添加到里面即可,这个时候你不仅会发现Activity里面的代码变少了很多,而且你开发起来也会根据清晰,逻辑更加简单。
以后在开发中可以用到这种编程思想,把我们的代码尽可能的减少,把复杂的界面划分成几个小的模块,逐一实现,逻辑放在各自独立的holder
里面,同时我们可以结合许多开源的框架来简化我们的开发。
总结一下,面向holder编程,实际上是对代码的再度封装,简化了我们开发的成本。
4 1
- android面向holder编程,再度封装代码
- android面向holder编程,再度封装代码
- Android-面向Holder编程
- Android应用面向Holder编程,附源码
- 面向Holder编程
- 面向holder编程
- 面向holder的编程,代码更清爽,管理更简单
- 安卓中面向MVC的开发(面向Holder的编程)
- Android RecyclerView Adapter及Holder的封装【原创】
- 基类holder封装
- Android SQLite 建表 面向对象编程 完美封装 一劳永逸
- Android RecyclerView(五)封装Holder与Adapter(Android 5.0 新特性)
- javascript面向对象编程封装
- Javascript面向对象编程:封装
- Javascript 面向对象编程:封装
- 面向对象编程思想---封装
- Python面向对象编程-封装
- javascript面向对象编程:封装
- Oracle中的Truncate和Delete语句
- 【笔试】25、栈和队列
- 循环下载图片,跳过不可用url
- android apk与apk 之间互相通信--如何自定义权限
- 视图
- android面向holder编程,再度封装代码
- org.apache.hadoop中遇到的API记录
- POJ 2513 Colored Sticks (Trie树,欧拉通路,并查集)
- 显卡NVIDIA,AMD,ATI的区别
- POJ 3026 Borg Maze(BFS+最小生成树)
- Spring MVC之@RequestMapping 详解
- oracle job 时间的配置
- 努力的时光是本书,翻一页是一页
- 【笔试】26、旋转数组的最小数字