Android列表组件ListView使用详解之动态加载或修改列表数据

在使用ListView组件来显示列表数据时,有的时候我们需要改变列表中的数据,有以下方法:

1、重新给ListView组件设置适配器

这种方法重新创建了ListView,效率不好。

2、使用适配器中的方法

/**
   * Notifies the attached observers that the underlying data has been changed
   * and any View reflecting the data set should refresh itself.
   */
  public void notifyDataSetChanged() {
    mDataSetObservable.notifyChanged();
  }

这种方法旨在告知适配器,ListView中的数据源发生变化,需要重新加载新的数据,不会重新创建ListView。使用此方法时,需要确保使用的是同一数据存储对象,只是存储对象中的值发生变化,才能使改动生效。关键代码如下:

listViewDemoAdapter.notifyDataSetChanged();

效果图:

当前界面显示的代码:

package net.oschina.git.zhaikun.androiddeveloped.activitys;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.ListView;
import net.oschina.git.zhaikun.androiddeveloped.R;
import net.oschina.git.zhaikun.androiddeveloped.adapter.ListViewDemoAdapter;
import java.util.ArrayList;
import java.util.List;
/**
 * Created by zhaikun68 on 2018/3/5.
 * <p>
 * ListView演示Demo
 */
public class ListViewDemoActivity extends AppCompatActivity implements View.OnClickListener {
  private ListView testLv;//ListView组件
  private Button updateDataBtn;//动态加载数据组件
  private List<String> dataList = new ArrayList<>();//存储数据
  private ListViewDemoAdapter listViewDemoAdapter;//ListView的数据适配器
  @Override
  protected void onCreate(@Nullable Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_listview_demo);
    initView();//初始化组件
    initData();//初始化数据
  }
  /**
   * 初始化组件
   */
  private void initView() {
    testLv = (ListView) findViewById(R.id.test_lv);
    updateDataBtn = (Button) findViewById(R.id.update_data_btn);
    updateDataBtn.setOnClickListener(this);
  }
  /**
   * 初始化数据
   */
  private void initData() {
    //初始化10项数据
    for (int i = 1; i <= 20; i++) {
      dataList.add("显示内容" + i);
    }
    //设置ListView的适配器
    listViewDemoAdapter = new ListViewDemoAdapter(this, dataList);
    testLv.setAdapter(listViewDemoAdapter);
    testLv.setSelection(4);
  }
  @Override
  public void onClick(View v) {
    switch (v.getId()) {
      case R.id.update_data_btn://动态加载列表数据
        dataList.add("动态加载的数据项");
        //通知ListView更改数据源
        if (listViewDemoAdapter != null) {
          listViewDemoAdapter.notifyDataSetChanged();
          testLv.setSelection(dataList.size() - 1);//设置显示列表的最后一项
        } else {
          listViewDemoAdapter = new ListViewDemoAdapter(this, dataList);
          testLv.setAdapter(listViewDemoAdapter);
          testLv.setSelection(dataList.size() - 1);
        }
        break;
    }
  }
}

界面布局文件:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
  <Button
    android:id="@+id/update_data_btn"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_margin="10dp"
    android:text="动态加载数据"/>
  <ListView
    android:id="@+id/test_lv"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_above="@id/update_data_btn"
    android:divider="@color/colorPrimaryDark"
    android:dividerHeight="3dp"
    android:listSelector="#ff0000"
    android:scrollbars="none"/>
</RelativeLayout>

适配器代码:

package net.oschina.git.zhaikun.androiddeveloped.adapter;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;
import net.oschina.git.zhaikun.androiddeveloped.R;
import java.util.List;
/**
 * Created by zhaikun68 on 2018/3/5.
 * <p>
 * ListView演示Demo中的数据适配器
 */
public class ListViewDemoAdapter extends BaseAdapter {
  private Context context;//上下文对象
  private List<String> dataList;//ListView显示的数据
  /**
   * 构造器
   *
   * @param context 上下文对象
   * @param dataList 数据
   */
  public ListViewDemoAdapter(Context context, List<String> dataList) {
    this.context = context;
    this.dataList = dataList;
  }
  @Override
  public int getCount() {
    return dataList == null ? 0 : dataList.size();
  }
  @Override
  public Object getItem(int position) {
    return dataList.get(position);
  }
  @Override
  public long getItemId(int position) {
    return position;
  }
  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    ViewHolder viewHolder;
    //判断是否有缓存
    if (convertView == null) {
      convertView = LayoutInflater.from(context).inflate(R.layout.item_listview_demo, null);
      viewHolder = new ViewHolder(convertView);
      convertView.setTag(viewHolder);
    } else {
      //得到缓存的布局
      viewHolder = (ViewHolder) convertView.getTag();
    }
    //设置图片
    viewHolder.pictureImg.setImageResource(R.mipmap.ic_launcher);
    //设置内容
    viewHolder.contentTv.setText(dataList.get(position));
    return convertView;
  }
  /**
   * ViewHolder类
   */
  private final class ViewHolder {
    ImageView pictureImg;//图片
    TextView contentTv;//内容
    /**
     * 构造器
     *
     * @param view 视图组件(ListView的子项视图)
     */
    ViewHolder(View view) {
      pictureImg = (ImageView) view.findViewById(R.id.picture_img);
      contentTv = (TextView) view.findViewById(R.id.content_tv);
    }
  }
}

列表子项的布局文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
       android:layout_width="match_parent"
       android:layout_height="wrap_content"
       android:orientation="horizontal"
       android:padding="5dp">
  <ImageView
    android:id="@+id/picture_img"
    android:layout_width="30dp"
    android:layout_height="30dp"
    android:layout_marginRight="5dp"
    android:src="@mipmap/ic_launcher"/>
  <TextView
    android:id="@+id/content_tv"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center_vertical"
    android:text="显示内容"/>
</LinearLayout>

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接

(0)

相关推荐

  • Android应用动态修改主题的方法示例

    1.使用API设置主题 如下所示,在Activity中使用setTheme setTheme(R.style.MyTheme1); 2.调用API的时机 需要在super.onCreate(savedInstanceState)之前调用setTheme 3.重新设置主题 要重新设置主题,则需要结束Activity,重新启动才可以 public class MainActivity extends Activity { private TextView tv; @Override protecte

  • Android动态添加碎片代码实例

    碎片的创建 要使用碎片先要创建一个碎片,创建一个碎片很简单. 1.新建一个碎片布局,fragment.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" and

  • Android动态显示具体到秒的相聚时间

    本文实例为大家分享了Android动态显示相聚时间的具体代码,供大家参考,具体内容如下 目标效果: 主要功能代码: @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar

  • Android自定义动态壁纸开发(时钟)

    看到有些手机酷炫的动态壁纸,有没有好奇过他们是如何实现的,其实我们自己也可以实现. 先看效果 上图是动态壁纸钟的一个时钟. 我们先来看看 Livewallpaper(即动态墙纸)的实现,Android的动态墙纸并不是GIF图片,而是一个标准的Android应用程序,也就是APK.既然是应用程序,当然意味着天生具有GIF图片不具备的功能--能与用户发生交互,而且动态的背景变化绝不仅仅局限于GIF图片那般只能是固定的几张图片的循环播放.但是我们在这里没有加入与用户交互的动作,只是加入一个时钟(当然时

  • Android动态布局使用详解

    本文为大家分享了Android动态布局的实现代码,供大家参考,具体内容如下 内容如下:介绍多种实现动态布局的方法,以及如何用代码来调整View位置 这里只介绍三种布局情况(注意不是方式) 1.无xml : 一个父类布局包含一个子父类布局,子父类布局中包含ImageView 2.无xml : 只有一个父类布局包含一个ImageView 3.有xlm布局: 通过布局ID 来进行动态布局添加 总结了下其实步骤如下: 无xml布局: 1.setContentView()之前new一个需要的布局layou

  • Android Fragment(动态,静态)碎片详解及总结

    Android Fragment(动态,静态)碎片详解 一.Fragment的相关概念(一)Fragment的基础知识 Fragment是Android3.0新增的概念,中文意思是碎片,它与Activity十分相似,用来在一个 Activity中描述一些行为或一部分用户界面.使用多个Fragment可以在一个单独的Activity中建 立多个UI面板,也可以在多个Activity中使用Fragment. Fragment拥有自己的生命 周期和接收.处理用户的事件,这样就不必在Activity写一

  • Android列表组件ListView使用详解之动态加载或修改列表数据

    在使用ListView组件来显示列表数据时,有的时候我们需要改变列表中的数据,有以下方法: 1.重新给ListView组件设置适配器 这种方法重新创建了ListView,效率不好. 2.使用适配器中的方法 /** * Notifies the attached observers that the underlying data has been changed * and any View reflecting the data set should refresh itself. */ pu

  • 详解vue 动态加载并注册组件且通过 render动态创建该组件

    基于 iview Tabs 组件实现 功能:为每个 tab 动态创建不同的.特定的组件内容,而不需要大量的 import 组件并进行 component 注册 Index.vue <template> <div class="content-left-menu"> <div class="item-contain layout-content"> <Tabs class="cmcc-ivu-tab2" t

  • 详解Java动态加载数据库驱动

    问题背景 在同一套系统中,要支持连接访问各种流行的数据库,以及同一数据库的不同版本,例如,oracle9i.oracle10g.oracle11g.oracle12c.sqlserver2000.sqlserver2005.sqlserver2008.sqlserver2012等,其中就会碰到一些问题,就是不同的数据库,数据库驱动肯定不同,对于这个问题到好解决,只需要将相应的驱动加入即可:然而对于同种数据库,不同版本时,而且不同版本的数据库驱动不仅不兼容,同时存在还会出现冲突,例如,能满足sql

  • 详解vue模拟加载更多功能(数据追加)

    使用vue制作加载更多功能,通过ajax获取的数据往data里面push经常不成功,原因是push是往数组中追加数据内容的,而不能用作数组之间的拼接,ajax获取的数据就是数组形式的,因此不成功,应该使用concat()拼接两个数组. //这是错误的写法 $.ajax({ type:'get', async:false, url:path+'no/noticeMobile/getSendNoticeList?imToken='+ getToken +'&pageFlag=2', dataType

  • Android开发实现的ViewPager引导页功能(动态加载指示器)详解

    本文实例讲述了Android开发实现的ViewPager引导页功能(动态加载指示器).分享给大家供大家参考,具体如下: 先看效果图咯~ 现在几乎每个App都会有引导页,是不是感觉很炫很厉害,所以就想做出来一个学习一下~让自己的App看起来更加的美观~ 现在来分析一下: 这个引导页可以分为俩部分~ 1.小红点--来提醒这是第几页了~ 2."开始体验"这个Button--可以进入主界面,但是要控制这个Button只能在最后一页出现 布局的话使用相对布局~ 那现在来看看布局吧: activi

  • 详解Spring ApplicationContext加载过程

    1.找准入口,使用ClassPathXmlApplicationContext的构造方法加载配置文件,用于加载classPath下的配置文件 //第一行,执行完成之后就完成了spring配置文件的加载,刷新spring上下文 ClassPathXmlApplicationContext context=new ClassPathXmlApplicationContext( "classpath:spring-mvc.xml"); //获取实例Bean Person person=con

  • 详解Vue3如何加载动态菜单

    目录 1. 整体思路 2. 实现细节 2.1 加载细节 2.2 getInfo 2.3 generateRoutes 1. 整体思路 首先我们来梳理下整体上的实现思路,首先一点:整体思路和 vhr 一模一样. 考虑到有的小伙伴可能已经忘记 vhr 中前端动态菜单的实现思路了,因此本文再和大家分析一下. 为了确保在所有的 .vue 文件中都能访问到到菜单数据,所以选择将菜单数据存入 vuex 中,vuex 是 vue 中一个存储数据的公共地方,所有的 .vue 文件都可以从 vuex 中读取到数据

  • 详解JS异步加载的三种方式

    一:同步加载 我们平时使用的最多的一种方式. <script src="http://yourdomain.com/script.js"></script> <script src="http://yourdomain.com/script.js"></script> 同步模式,又称阻塞模式,会阻止浏览器的后续处理,停止后续的解析,只有当当前加载完成,才能进行下一步操作.所以默认同步执行才是安全的.但这样如果js中有输

  • 详解Qt如何加载libxl库

    使用工具 1.Qt 5.12.3集成开发环境 2.libxl-3.9.4.3(官方下载地址:https://www.libxl.com/download.html) 提示:以下是本篇文章正文内容,下面案例可供参考 一.如何导入libxl库 由于官方给出的教程是MinGW32导入动态库我这边也照着导入libxl的32位动态库,使用MinGW64开发环境同理,如果qt使用的是mvsc环境的朋友可以不用参考此教程 1.pro文件导入静态链接库 1.把lib32.dll文件路径放入到pro文件中: LI

  • Spring详解四种加载配置项的方法

    目录 1.spring加载yml文件 2.spring 加载 properties 文件 3.spring加载系统磁盘(properties)文件 4.spring加载xml文件 5.Java基于InputStream读取properties配置文件 本文默认 spring 版本是 spring5 1 spring 加载 yml 文件 2 spring 加载 properties 文件 3 spring 加载 系统磁盘 文件 4 spring 加载 xml 文件 5 Java 基于 InputS

随机推荐