RecyclerView简介:

RecyclerView用以下两种方式简化了数据的展示和处理:
1. 使用LayoutManager来确定每一个item的排列方式。
2. 为增加和删除项目提供默认的动画效果,也可以自定义。

RecyclerView项目结构如下:

Adapter: 使用RecyclerView之前,你需要一个继承自RecyclerView.Adapter的适配器,作用是将数据与每一个条目的界面进行绑定。

LayoutManager: 用来确定每一个item如何进行排列摆放,何时展示和隐藏。

RecyclerView-Item添加:

在适配器中加入如下代码:

    //  添加数据
    public void addData(int position) {
//      在list中添加数据,并通知条目加入一条
        list.add(position, "我是商品" + position);
        //添加动画
        notifyItemInserted(position);
     adapter.addData(list.size());

RecyclerView-Item删除:

在适配器中加入如下代码:

   //  删除数据
    public void removeData(int position) {
        list.remove(position);
        //删除动画
        notifyItemRemoved(position);
        notifyDataSetChanged();
//Item里的删除
     removeData(position);
//外面的控件的删除
adapter.  removeData(position);

需要注意的是我再删除动画的下面加了notifyDataSetChanged();代码,因为我们在删除条目时不一定是按照顺序删除的,也许是错位删除,这样会因为position的原因造成角标越界异常,所以需要整体刷新一下。

整体代码:

1.MainActivity

package com.android.qzs.qzsrecycleview;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.DefaultItemAnimator;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.view.View;
import android.widget.ImageView;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
    private RecyclerView mRecyclerView;
    private ImageView iv_add;
    private RecycleAdapter adapter;
    private List<String> list = new ArrayList<String>();
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initView();
        initRecycle();
        iv_add.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //              添加自带默认动画
                    adapter.addData(list.size());
    private void initRecycle() {
        //  纵向滑动
        LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);
        mRecyclerView.setLayoutManager(linearLayoutManager);
//      获取数据,向适配器传数据,绑定适配器
        list = initData();
        adapter = new RecycleAdapter(MainActivity.this, list);
        mRecyclerView.setAdapter(adapter);
//      添加动画
        mRecyclerView.setItemAnimator(new DefaultItemAnimator());
    private void initView() {
        iv_add = (ImageView) findViewById(R.id.iv_add);
        mRecyclerView = (RecyclerView) findViewById(R.id.recyclerview);
    protected ArrayList<String> initData() {
        ArrayList<String> mDatas = new ArrayList<String>();
        for (int i = 0; i < 1; i++) {
            mDatas.add("我是商品" + i);
        return mDatas;

2.RecycleAdapter

package com.android.qzs.qzsrecycleview;
import android.content.Context;
import android.support.design.widget.Snackbar;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import java.util.ArrayList;
import java.util.List;
 * Created by qzs on 2017/9/04.
class RecycleAdapter extends RecyclerView.Adapter<RecycleAdapter.MyViewHolder> {
    private Context context;
    private List<String> list;
    public RecycleAdapter(Context context, List<String> list) {
        this.context = context;
        this.list = list;
    @Override
    public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        MyViewHolder holder = new MyViewHolder(LayoutInflater.from(
                context).inflate(R.layout.item_home, parent,
                false));
        return holder;
    @Override
    public void onBindViewHolder(MyViewHolder holder, final int position) {
        holder.tv.setText(list.get(position));
        holder.tv_delete.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if (list.size() == 1) {
                    Snackbar.make(v, "此条目不能删除", Snackbar.LENGTH_SHORT).show();
                } else {
                    //               删除自带默认动画
                    removeData(position);
    @Override
    public int getItemCount() {
        return list.size();
    //  添加数据
    public void addData(int position) {
//      在list中添加数据,并通知条目加入一条
        list.add(position, "我是商品" + position);
        //添加动画
        notifyItemInserted(position);
    //  删除数据
    public void removeData(int position) {
        list.remove(position);
        //删除动画
        notifyItemRemoved(position);
        notifyDataSetChanged();
     * ViewHolder的类,用于缓存控件
    class MyViewHolder extends RecyclerView.ViewHolder {
        TextView tv, tv_delete;
        //因为删除有可能会删除中间条目,然后会造成角标越界,所以必须整体刷新一下!
        public MyViewHolder(View view) {
            super(view);
            tv = (TextView) view.findViewById(R.id.id_num);
            tv_delete = (TextView) view.findViewById(R.id.tv_delete);

源码下载地址

我的公众号如下

Android-RecyclerView ###This demo demonstrates the common functions of RecyclerView ###DEMO实现功能: RecyclerView的点击事件: Itemitem中的子View添加点击事件 RecyclerView Item之间添加分隔线:垂直与水平方向 RecyclerView 单个与多个Item添加删除 RecyclerView Item添加删除动画效果 RecyclerView滚动状态监听 LayoutManager的使用 ###DEMO效果图: RecyclerView 已经出来很长时间了,但是一直都没有去体验一把这个高大上的控件,要准备开始用AndroidStadio,就一起当练手了。        RecyclerView是谷歌V7包下新增的控件( android.support.v7.widget.RecyclerView ),用来代替ListView使用,他可以通过设置LayoutManager来快速实现listview、gri 如果对这个RecyclerView的网格视图的实现有疑问的话,请参考我的另一篇文章: https://blog.csdn.net/weixin_43344890/article/details/89429821 如果对标题栏按钮的实现有什么疑问的话,请参考我的另一篇文章: 我这里重点讲怎么增删item。 三级缓存,有的地方说是四级缓存,请你不要迷惑,到底是三还是四,这就像图片加载这个场景有人说是三级缓存有人说是二级缓存,说三级缓存是把通过网络请求图片这个环节也认为是一层缓存,你认为这个环节应该不应该属于缓存呢?所以到底是三还是四不重要,因为逻辑是固定的.其实如果要比较和ScrollView这两个哪个控件使用起来更简单,那必然是ScrollView,而且上手难度完全不是一个量级的.那为什么ScrollView的出镜率完全比不上呢?这就要归功于缓存设计和他的可扩展性了. 最近在做一项目,项目中用到了一个功能,要求是动态Item,而且是多个的情况下,不过仔细的分析了下,都大同小异,做起来也很简单,在这里我只抽取出来做了一demo,也只做了一个动态添加item,同时可以获取所有添加和编辑Item上的数据,先上图: 我们先来分析一下这个demo: 两个TextView和EditText,一个Button,一个星级评价RatingBar控件,布局完事… activity_dynamic的布局,有可能会添加多个,所以外面用ScrollView,因为我们是垂直方向添加,所以使用LinearLayout做容器 <?xml version=1.0 encoding= Android OnClickListener的三种实现方式参考 1、https://blog.csdn.net/da_da_xiong/article/details/73256898?utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7Edefault-3.no_search_link&depth_1-utm_source=distribute.pc_relevant.none-task-blog- GridLayoutManager linearLayoutManager = new GridLayoutManager(this, 4); linearLayoutManager.setOrientation(LinearLay...     最近遇到一个需求:会话列表页面需要能动态添加一个可高度定制的Item。小小总结下自己的实现方式。    一般情况下,在RecyclerView中我们引进不同的Item类型,都是提前确定好的,那如果遇到不确定类型的Item,如何处理?那么就需要可以动态添加,灵活抽插,才是王道。... Android_Banner.jpg简介本节中我们介绍下给RecyclerView中的Item添加动画。添加的动画,分为,在打开列表时有Item的展示动画,当滑动的时候没有动画和打开列表滑动时有动画两种实现过程实现一个列表效果如下Screenshot_2020-09-01-17-03-35-349_com.dashingqi.module.recyclerview.png接下来我们就要操作这个列表... RecyclerView与ListView原理是类似的:都是仅仅维护少量的View并且可以展示大量的数据集。RecyclerView用以下两种方式简化了数据的展示和处理: 使用LayoutManager来确定每一个item的排列方式。 为增加和删除项目提供默认的动画效果。 RecyclerView虽然作为ListView的替代者有着较好的性能提升,但是ListView的一些常用功能却没有提供,比如我们平时会经常用到的addHeaderView,addFooterView,既然RecyclerView没有提供这个方法,我们应该如何为列表添加头部和底部呢?通过看ListView的源码可以知道Li 先给大家展示下大概效果图: Android上面有许多的教程, 库和示例, 在RecyclerView上面实现”拖放”和”滑动删除”功能. 尽管有更新, 更好的方法可用, 但是大多数人依然使用旧的View.OnDragListener和Roman Nurik的SwipeToDismiss方式. 除了经常使用GestureDetector和onInterceptTouchEvent之外, 几乎很少有人使用新的API, 要不然的话, 实现就复杂. 事实上真的有十分简单的方式在RecyclerView上面添加这两个功能. 它只要求一个类, 而且这个类已经是Android支持包的一部分. ItemTo 项目中要求实现一个可以选择类型以及编辑的item,还要可以根据选择的类型能够动态的添加删除一行。实现的效果下图:大体要求如下:点击左侧下拉菜单弹出一系列选项可以选择类别、点击右侧editText可以编辑金额、点击圆形+号动态添加一行(-号删除一行)。从这个代码的实现意识到两点:1、当你喜欢用别人封装好的框架时,别人的框架比如自己写的adapter有很多好处,可以让代码简练等但同时也限制了你自己的... 近来在做一个Android项目,用到了RecyclerView。相比ListView单调的notifydatasetchanged,RecyclerView添加/删除Item时有多种方法可以选择。 例如:添加Item可以用notifyItemInserted和notifyItemRangeInserted,删除Item可以用notifyItemRemoved和notifyItemRangeRe 1.有动画添加(只用执行这一条语句,自动刷新recyclerview) mAdapter.notifyItemInserted(mAdapter.getItemCount()); 2.更新数据源并刷新 mRows.add(item);//更新数据源 mAdapter.notifyDataSetChanged();