在项目中经常会用到列表类的展示,遇到这种需求,我们会选择的是ListView或者RecycleView。
在有了RecycleView后,就很少用ListView了。可以说RecycleView完美替换了ListView。RecycleView可以满足我们在开发中使用ListView能实现的一切需求。
那在使用RecycleView的过程中,小菜鸟遇到了下面的问题。
展示不同类型的item。也就是在展示的列表中有不同的样式。这个时候我们会按下面这种方式使用。
/**
* 决定元素的布局使用哪种类型 *
* @param position 数据源的下标 * @return 一个int型标志,传递给onCreateViewHolder的第二个参数 */
@Override
public int getItemViewType(int position) {
return mDatas.get(position).getType();
}/** * 渲染具体的ViewHolder
*
* @param parent ViewHolder的容器 * @param viewType 一个标志,我们根据该标志可以实现渲染不同类型的ViewHolder
* @return
*/
@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
Log.e("terry", "viewType = " + viewType);
View view = null;
if (viewType == 1) {
view = LayoutInflater.from(parent.getContext()).inflate(R.layout.comment_main_first, parent, false);
} else if (viewType == 2) {
view = LayoutInflater.from(parent.getContext()).inflate(R.layout.comment_main_second, parent, false);
}
return new ViewHolder(view, mContext);
}
主要是上面的两个方法。其他的关于RecycleView的使用今天就不做分享了。
上面只写了两个不同的item。要是item的数量很多呢?如果是100个。那这样不是要写100个else if的判断吗?
带着上面的问题,小菜鸟搜索了很多资料,总结出下面的优化技巧。希望可以给你也带来一些启发。
优化技巧--使用布局文件资源id直接作为viewType的返回
那么如何使用呢?
把你的布局文件命名为比较有规律的名字,小菜鸟就是这样命名的:item_0、item_1...就这样递增。通过循环就可以解决,不同命名引起的else if的多个判断。后面的标准一定要和type相同哦。
/**
*
* @param context
* @param name xml的文件名
* @param defType xml的类型,如R.layout、R.id、R.drawable
* @return
*/
private int getResId(Context context, String name, String defType) {
String packageName = context.getPackageName();
return context.getResources().getIdentifier(name, defType, packageName);
}
// 使用 用布局文件的id作为直接返回
@Override
public int getItemViewType(int position) { // 在设置的数据中,获取type
this.type = getItem(position).getType();
return getResId(mContext, "item_" + type, "layout");
}
优化后的代码
/** * 渲染具体的ViewHolder
* 优化后的代码只有一行了。不再需要else if 的判断了。* @param parent ViewHolder的容器 * @param viewType 一个标志,我们根据该标志可以实现渲染不同类型的ViewHolder
* @return
*/
@Override
public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = null;
view = LayoutInflater.from(parent.getContext()).inflate(viewType, parent, false);
return new ViewHolder(view, mContext);
}
------ END ---------
关注我
每天进步一点点