首页 > 代码库 > ListView嵌套ListView优化

ListView嵌套ListView优化

在做业务时候,一个ListView显示多种数据类型,我们想到的方法是ListView在嵌套一个ListView,对于子ListView
占父ListView的一行,就解决了问题,但是这样的逻辑是不是有点奇怪呢?


第一,父ListView的长度size需要加1,因为增加了一行放子listView
    public int getCount() {
        return datas.size()+1;
    }

第二,需要判断在什么地方插入子listView ,就要用到getViewTypeCount()和getItemViewType (int position)两个方法

public int getItemViewType (int position){
        if(position==CHRILDLOCATION){//插入子ListView位置
             return  TYPE_0;//TYPE_0表示子ListView标志
       }
          
return  TYPE_1;//TYPE_1表示父ListView标志

}

第三,需要在父UI更新时候,当position>CHRILDLOCATION时对position-1,因为你在前面插入了子listView,其实后
面得到的position,都占了一个位置.需要这时候减去
这三步理解起来就让人够烦了,很混乱吧,还有更糟糕的事情,就是,子ListView你还要new 一个Adapter来遍历

出它的item,这样就形成循环中嵌套循环,你的代码性能是不是很差。


重点来了:

我们可以在传入Adapter的数据中做文章,把不同的数据类型都用Object代替,然后把Object放入List集合,

在Adapter,判断类型,比如:一个商品列表,中间会杂着一些商品主题团,我们就通过List<Object>封装

这两种数据类型,实现对上面ListView嵌套的讲解。


第一,在Adapter之外封装成一个List<Object>,就不需要在用到子ListView了,数据都在list中,也就不需要对

datas.size()+1的操作了,只需要判断数据类型,然后做上面第二步操作;

public int getItemViewType (int position){
        if(datas.get(position) instanceof “商品主题团”){
             return  TYPE_0;//TYPE_0表示商品主题团

       }
          

return  TYPE_1;//TYPE_1表示商品

}


完了,也就不需要对数据更新Ui时候减一操作,避免了降低了出错的概率。
主要是不需要在getView中在new Adapter了,性能提高很大。