原文:ListView 控件和 INotifyPropertyChanged 接口

ListView 控件和 DataGridView 控件

ListView 是跟 Winform 中 DataGridView 用法以及显示效果差不多的一个 WPF 控件,可以通过列表的方式方便的显示数据;

<!-- ListView 控件 Xaml 代码 -->
<ListView Name="listView" Margin="10,10,9.6,10">
<ListView.View>
<GridView>
<GridViewColumn Header="任务"/>
<GridViewColumn Header="任务描述"/>
<GridViewColumn Header="循环周期(秒)"/>
<GridViewColumn Header="任务状态/>
</GridView>
</ListView.View>
</ListView>

DataGridView 控件的使用中,通常我们都会创建一个类用来储存数据,读取数据之后再创建一个这个类的集合,然后将集合赋给 dataGridView1.DataSource 属性;也可不用集合,直接在循环中把数据一条一条的加载 dateGridView1.Rows.Add()

// 先创建一个用来储存数据的类
class UserInfo
{
public string Name { get; set; }
public int Age { get; set; }
}
// WinForm:DataGridView 控件
// 方法一:创建一个对象集合,赋值给 DataSource 属性
List<UserInfo> infos = new List<UserInfo>();
for(int i = 0; i > 10; i++)
{
infos.Add(new UserInfo
{
Name = $"Light_{i}",
Age = i
});
}
dataGridView1.DataSource = infos; // 方法二:一条一条的添加数据
for(int i = 0; i > 10; i++)
{
dateGridView1.Rows.Add(new UserInfo
{
Name = $"Light_{i}",
Age = i
});
}

在 ListView 控件中 DataSource 属性在这里是 listView.ItemsSource;单条数据加载的方法是 listView.Items.Add();,整体用法还是大同小异;

// WPF:ListView 控件
// 方法一:创建一个对象集合,赋值给 ItemsSource 属性
List<UserInfo> infos = new List<UserInfo>();
for(int i = 0; i > 10; i++)
{
infos.Add(new UserInfo
{
Name = $"Light_{i}",
Age = i
});
}
listView.ItemsSource = infos; // 方法二:一条一条的添加数据
for(int i = 0; i > 10; i++)
{
listView.Items.Add(new UserInfo
{
Name = $"Light_{i}",
Age = i
});
}

INotifyPropertyChanged 接口

命名空间:System.ComponentModel

INotifyPropertyChanged 是一个非常强大的接口,用于向对象绑定的客户端控件发出对象属性已更改的通知;

用人话说就是:正常我们向上面一样,把对象绑定到控件用来显示数据,有一个缺点:每次更改对象的属性之后,我们需要手动的重新再去绑定数据,否则数据是不会刷新显示修改后的值的;

但是如果对象实现了 INotifyPropertyChanged 接口的话,我们根本不用担心这些问题,直接修改已绑定对象的属性,客户端就会自动刷新显示数据;

比如说,上面我们创建的 UserInfo 类就可以修改成这样:

class UserInfo : System.ComponentModel.INotifyPropertyChanged
{
private string name;
private int age; // 属性发生更改时触发的事件,由每个属性的 Set 访问器调用
public event PropertyChangedEventHandler PropertyChanged; public string Name
{
get => name;
set
{
name = value;
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs("Name"));
}
}
public string Age
{
get => age;
set
{
age = value;
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs("Age"));
}
}
}

这样创建完成后,我们再安装上面的方法将对象绑定客户端控件,之后每次修改数据,就可以直接获取绑定的对象然后修改对象属性就可以了,无需再做任何操作;

// DataGridView 控件
// 获取选中行,返回当前绑定对象
UserInfo info = (UserInfo)dataGridView1.SelectedRows[0].DataBoundItem;
info.Name = "Liang";
info.Age = 18;
// ListView 控件
// 获取选中行,返回当前绑定对象
UserInfo info = (UserInfo)listView.SelectedItem;
info.Name = "Liang";
info.Age = 18;

ListView 控件和 INotifyPropertyChanged 接口的更多相关文章

  1. C# ListView 控件和 INotifyPropertyChanged 接口

    ListView 控件和 DataGridView 控件 ListView 是跟 Winform 中 DataGridView 用法以及显示效果差不多的一个 WPF 控件,可以通过列表的方式方便的显示 ...

  2. ListView控件--2016年12月9日

    ListView属性 ListView   名称 说明 AccessKey 重写 WebControl.AccessKey 属性. 不支持将此属性设置 ListView 控件.(覆盖 WebContr ...

  3. 《ASP.NET1200例》ListView 控件与DataPager控件的结合<一>

    分页     在前一部分开始时介绍的原 HTML 设计中内含分页和排序,所以根据规范完整实现该网格的任务尚未完成.我们先分页,然后再排序. ListView 控件中的分页通过引入另一个新控件 Data ...

  4. 【Android基础】listview控件的使用(3)------Map与SimpleAdapter组成的多显示条目的Listview

    前面介绍的两种listview的使用都是最基础的,所以有很大的局限性,比如只能在一个item(即每一行的条目)中显示一个文本信息,这一篇我将介绍Map与SimpleAdapter组成的多显示条目的Li ...

  5. 【Android基础】listview控件的使用(2)-------继承自ListActivity的普通listview

    由于listview在android控件中的重要性,所以android为我们直接封装了一个类ListviewActivity,直接将listview封装在了activity之中,在本篇中,我将介绍在L ...

  6. 【Android基础】listview控件的使用(1)------最简单的listview的使用

    listview控件是项目开发中最常用的空间之一,我将慢慢推出关于listview的一系列的文章,先从最简单的,系统自带的listview开始吧! 先上效果图: activity_one.xml &l ...

  7. C#:ListView控件如何实现点击列表头进行排序?

    using System; using System.Collections; using System.Windows.Forms; namespace Common { /// <summa ...

  8. ListView控件

      打气筒工具:将R.layout.item_listview布局添加到相应的view控件里面 View view=LayoutInflater.from(ScondPro.this).inflate ...

  9. Android中ListView控件的使用

    Android中ListView控件的使用 ListView展示数据的原理 在Android中,其实ListView就相当于web中的jsp,Adapter是适配器,它就相当于web中的Servlet ...

随机推荐

  1. Apex 的 Trigger 类简介

    Apex Triggers Apex 触发器(Apex Triggers)是一种特殊的 Apex 类.它的主要作用是在一条记录被插入.修改.删除之前或之后自动执行一系列的操作.每一个 Trigger ...

  2. K邻近分类算法

    # -*- coding: utf-8 -*- """ Created on Thu Jun 28 17:16:19 2018 @author: zhen "& ...

  3. Tensorflow实现稀疏自动编码(SAE)

    1.概述 人在获取图像时,并不是像计算机逐个像素去读,一般是扫一眼物体,大致能得到需要的信息,如形状,颜色,特征.怎么让机器也有这项能力呢,稀疏编码来了. 定义: 稀疏自编码器(Sparse Auto ...

  4. [20171227]表的FULL_HASH_VALUE值的计算.txt

    [20171227]表的FULL_HASH_VALUE值的计算.txt --//sql_id的计算是使用MD5算法进行哈希,生成一个128位的Hash Value,其中低32位作为HASH VALUE ...

  5. python第五十二天---第九周作业 类 Fabric 主机管理程序

    类 Fabric 主机管理程序开发:1. 运行程序列出主机组或者主机列表2. 选择指定主机或主机组3. 选择让主机或者主机组执行命令或者向其传输文件(上传/下载)4. 充分使用多线程或多进程5. 不同 ...

  6. java web中java和python混合使用

    利用java web技术展示python算法处理后的数据 工具/原料   myeclipse10 pycharm+Anaconda2 方法/步骤     首先安装配置好pycharm+Anaconda ...

  7. zabbix监控磁盘IO

    我这里有两种方法,感觉都不错.我这里主要是写一下监控的脚本. 1.使用iostat命令监控 1)首先打开配置文件的自定义脚本功能,然后编写脚本. #!/bin/bash ];then echo &qu ...

  8. vue_模板渲染

    渲染 当获取到后端数据后,我们会把它按照一定的规则加载到写好的模板中,输出成在浏览器中显示的HTML,这个过程就称之为渲染. vue.js是在前端(即浏览器内)进行的模板渲染. 前后端渲染对比 前端渲 ...

  9. rowid快速分页解析

    版权声明:个人随笔,实用你就COPY,看不懂不解释 https://blog.csdn.net/HelloCqk1/article/details/36628787 --分页第一步 获取数据物理地址 ...

  10. SpringMVC---applicationContext.xml

    <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...