美文网首页
用委托者模式实现的多类型Adapter

用委托者模式实现的多类型Adapter

作者: Natchi | 来源:发表于2019-04-22 16:04 被阅读0次

场景

面对多类型的列表,应该怎么处理?

解决方案(设计思想的方法--委托者模式)

什么是委托者模式,简单的来说就是业务所需要实现的逻辑交给一个目标实现类来完成。
不管任何条目,都统一实现IDelegateAdapter接口



然后让一个实现类去完成


下面是代码实现

public interface IDelegateAdapter {


    // 查找委托时调用的方法,返回自己能处理的类型即可。
    boolean isForViewType(BaseRvBean baseRvBean);

    // 用于委托Adapter的onCreateViewHolder方法
    SuperViewHolder onCreateViewHolder(ViewGroup parent, int viewType);

    // 用于委托Adapter的onBindViewHolder方法
    void onBindViewHolder(RecyclerView.ViewHolder holder, int position, BaseRvBean baseRvBean);

    //清除数据
    void clearData();

}

由于篇幅原因,代码没有全部贴入

public class BaseRvAdapter extends RecyclerView.Adapter<SuperViewHolder> {
    List<IDelegateAdapter> delegateAdapters = new ArrayList<>();

    public void addDelegate(IDelegateAdapter delegateAdapter) {
        delegateAdapters.add(delegateAdapter);
    }

    @Override
    public SuperViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        IDelegateAdapter iDelegateAdapter = delegateAdapters.get(viewType);
        return iDelegateAdapter.onCreateViewHolder(parent, viewType);
    }

    @Override
    public void onBindViewHolder(SuperViewHolder holder, int position) {
        int itemViewType = holder.getItemViewType();
        IDelegateAdapter iDelegateAdapter = delegateAdapters.get(itemViewType);
        iDelegateAdapter.onBindViewHolder(holder, position, mDataList.get(position));
    }


    @Override
    public int getItemViewType(int position) {
        BaseRvBean baseRvBean = mDataList.get(position);
        for (IDelegateAdapter delegateAdapter : delegateAdapters) {
            if (delegateAdapter.isForViewType(baseRvBean)) {
                return delegateAdapters.indexOf(delegateAdapter);
            }

        }

        throw new RuntimeException("没有可以处理的委托Adapter");
    }

    public void clear() {
        mDataList.clear();
        for (IDelegateAdapter delegateAdapter : delegateAdapters) {
            delegateAdapter.clearData();
        }
        notifyDataSetChanged();
    }
}

使用方法

  1. 实现自己业务需要的item类型
class EditTextAdapter : IDelegateAdapter {
    override fun clearData() {
        mTextCache.clear()
    }

    override fun isForViewType(baseRvBean: BaseRvBean?): Boolean {

        return baseRvBean?.type == ViewType.ITEM_TYPE_GENERAL_EDITTEXT
    }

    @SuppressLint("InflateParams")
    override fun onCreateViewHolder(parent: ViewGroup?, viewType: Int): SuperViewHolder {
        val view = LayoutInflater.from(parent?.context).inflate(R.layout.view_custom_ed, null)
        return ViewHolder(view)
    }


    private val mTextCache = SparseArray<String>()
    override fun onBindViewHolder(holder: RecyclerView.ViewHolder?, position: Int, baseRvBean: BaseRvBean?) {
    }
  1. 创建Adapter
mAdapter = BaseRvAdapter(mActivity).apply {
           addDelegate(EditTextAdapter())
       }
  1. 赋值
mAdapter?.setDataList(mDataList )\\这些都是基本操作,大家都会的

委托模式是不是很简单呀,把设计模式运用到开发中,真的是件很有意思的事情,大家都可以多尝试下

相关文章

  • 用委托者模式实现的多类型Adapter

    场景 面对多类型的列表,应该怎么处理? 解决方案(设计思想的方法--委托者模式) 什么是委托者模式,简单的来说就是...

  • 使用 Kotlin 委托(Delegation) 实现 Andr

    委托模式(代理模式)是一种常见的设计模式,委托模式使得我们可以用聚合来替代继承,将委托者与实际实现代码分离出来,以...

  • 设计模式之缺省适配模式

    缺省适配模式 缺省适配(Default Adapter)模式为一个接口提供缺省实现,这样子类型可以从这个缺省实现进...

  • 代理模式、破解WIFI教程

    代理模式 委托是一种设计模式,它允许类或结构体将一些需要它们负责的功能交由(委托)给其他的类型。 委托模式的实现很...

  • Kotlin学习之类与对象3

    委托 由委托实现 委托模式(https://zh.wikipedia.org/wiki/委托模式)已经证明是实现继...

  • C++面向对象设计

    组合、委托、继承 一、composition(组合)has-a 1 组合关系(Adapter 设计模式) 关系: ...

  • iOS 代理模式

    代理模式确定委托方和代理者。由委托方制定协议、规范接口。让任意类型的遵守协议的代理方设置为委托方需要的代理者,代理...

  • Swift5.1—委托

    委托是一种设计模式,它允许类或结构体将一些需要它们负责的功能委托给其他类型的实例。委托模式的实现很简单:定义协议来...

  • 第三周学习笔记Boolan

    窗体顶端 继承复合委托 复合Comosition表示hasa 设计模式 Adapter(改造 适配 配接) que...

  • 52个有效方法(23) - 通过委托与数据协议进行对象间的通信

    委托模式(Delegate pattern) 委托模式(Delegate pattern):用来实现对象间的通信 ...

网友评论

      本文标题:用委托者模式实现的多类型Adapter

      本文链接:https://www.haomeiwen.com/subject/kthfwqtx.html