C#的WPF作为现在微软主流的桌面程序开发平台,相比过去的MFC时代,有了非常多的不同。本人刚从MFC平台转过来,以为可以轻松上手,哪知碰到了很多问题,十分不解。不得不乖乖回去看了本书,再继续回到边左边边学的路上。在这边也推荐《深入浅出WPF》这本书,拿来上手还是极好的。

由于WPF以数据驱动UI的设计理念,很多控件用起来都与之前平台的相差很多,ListView控件算是有代表性的,这是进化的成果。关于该控件的应该,很多参考了这篇博文,如觉本人记述不清楚,可去查阅。
WPF的代码分为前端和后端两部分,前端为UI,负责与用户进行交互;而后端则负责算法和数据的执行。由于这种机制,我们程序员对两端都需要有一个大概的了解,且主要注重于后端,这点相比以前混起来的机制实在是好太多。
ListView控件的XAML代码大致如下书写:

<ListView x:Name="listView" Height="165" VerticalAlignment="Top" HorizontalAlignment="Left" Width="604" BorderThickness="0,0,0,1" BorderBrush="#FFC8CCD4"> <ListView.View> <!--设置列标签并将列成员与一个变量名称相绑定,以便后台链接修改--> <GridView> <GridViewColumn Header="姓名" Width="100" DisplayMemberBinding="{Binding Path=Name}"/> <GridViewColumn Header="工作年限" Width="100" DisplayMemberBinding="{Binding Path=WorkYears}"/> <GridViewColumn Header="工作电话" Width="100" DisplayMemberBinding="{Binding Path=WorkPhoneNumber}"/> <GridViewColumn Header="邮箱" Width="100" DisplayMemberBinding="{Binding Path=Email}"/> </GridView> </ListView.View>
</ListView>

代码中我们设置了一个四列,列项分别为“姓名”、“工作年限”、“工作电话”和“邮箱”的列表,并将各项的成员分别与一个变量名称相绑定。单单写这些代码就已经可以看到界面上有一个对应的列表出现,且可以编译运行。前端的工作也大致结束(定义出控件大致外观和给出绑定接口),具体数据内容,可交给后端来绑定。
接下来我们来写后端的c#代码:
先定义一个类,这个类中的变量将与上面列表项绑定的变量一一对应,这样我们实例化一个对象便将对应于列表的一行。

class personalInfo//个人信息类
{ private string _name; private int _workYears; private string _workPhoneNumber; private string _email; public string Email//get和set分别为只读和只写,这是绑定的正常写法,Email为我们要进行绑定的一个属性 { get { return _email; } set { _email = value; } } public string WorkPhoneNumber { get { return _workPhoneNumber; } set { _workPhoneNumber = value; } } public int WorkYears { get { return _workYears; } set { _workYears = value; } } public string Name { get { return _name; } set { _name = value; } } public personalInfo(string name, int workYears, string workPhoneNumber, string email)//构造函数 { _name = name; _workYears = workYears; _workPhoneNumber = workPhoneNumber; _email = email; }
}

定义了上面的类之后,我们在代码中使用System.Collections.ObjectModel这个命名空间,然后使用“ObervableCollection”即“动态数据集合类”来管理我们的类对象。

ObservableCollection<personalInfo> personalInfoList = new ObservableCollection<personalInfo>(); 之后,给数据集合添加类成员
personalInfoList.Add(new personalInfo("李白", 10, "134124", "libai@hotmail.com"));
personalInfoList.Add(new personalInfo("杜甫", 2, "242354", "dufu@hotmail.com"));
personalInfoList.Add(new personalInfo("苏轼", 4, "345356", "sushi@hotmail.com"));
personalInfoList.Add(new personalInfo("李清照", 3, "453546", "liqingzhao@hotmail.com"));
最后,把数据和UI绑定在一起便大功告成了
listView.ItemsSource = personalInfoList;

上面的代码编译之后便能看到列表框和里面的数据,由于“ObervableCollection”在数据添加和删除的时候后发送消息给UI,所以我们在添加和删除一项数据的时候UI会做相应的修改。然而如果修改类里面的内容的时候则不行,因为修改的时候没有发送消息通知UI,所以我们还需要给“personalInfo”类定义消息通知接口,让其数据发生改变的时候也给UI发送消息。该类修改如下(需要添加System.ComponentModel命名空间):

class personalInfo: INotifyPropertyChanged //个人信息类
{ private string _name; private int _workYears; private string _workPhoneNumber; private string _email; public event PropertyChangedEventHandler PropertyChanged; public string Email//get和set为只读和只写,体现C#l { get { return _email; } set{ _email = value; PropertyChanged(this, new PropertyChangedEventArgs("Email")); } } public string WorkPhoneNumber { get { return _workPhoneNumber; } set{ _workPhoneNumber = value; PropertyChanged(this, new PropertyChangedEventArgs("WorkPhoneNumber")); } } public int WorkYears { get { return _workYears; } set{ _workYears = value; PropertyChanged(this, new PropertyChangedEventArgs("WorkYears")); } } public string Name { get { return _name; } set{ _name = value; PropertyChanged(this, new PropertyChangedEventArgs("Name")); } } public personalInfo(string name, int workYears, string workPhoneNumber, string email)//构造函数 { _name = name; _workYears = workYears; _workPhoneNumber = workPhoneNumber; _email = email; }
}

这样,我们便实现了ListView控件的基本绑定、修改和显示功能了。

C# WPF ListView控件的实例详解相关推荐

  1. C#中WPF ListView绑定数据的实例详解

    C#中WPF ListView绑定数据的实例详解 发布时间: 2019-03-09 19:29:46 来源: 互联网 作者: 晨曦888 栏目: C#教程 点击: 298 这篇文章主要介绍了C#中WP ...

  2. Windows MObile中ListView控件的用法详解

    -前言:ListView在Windows Mobile中的应用非常广泛,也是Windows Mobile中很重要的一个控件,在此俺新手给他做个总结,方便其它新手参考哈! --------------- ...

  3. 布局中文件中【控件间距参数详解以及单位选择】

    注意:例如:android:layout_gravity和android:gravity的区别: android:layout_gravity:此控件相对父控件的相对位置 android:gravit ...

  4. ASP.NET技巧:GridView控件自定义分页详解第一页

    ASP.NET技巧:GridView控件自定义分页详解 日期:2007年9月11日 作者: 查看:[大字体 中字体 小字体] <script src="../gg/info468.js ...

  5. wxpython使用方法_python图形界面开发之wxPython树控件使用方法详解

    wxPython树控件介绍 树(tree)是一种通过层次结构展示信息的控件,如下图所示是树控件示例,左窗口中是树控件,在wxPython中树控件类是wx.TreeCtrl. wx.TreeCtrl常用 ...

  6. WPF 控件专题 GridSplitter详解

    1.GridSplitter 介绍 GridSplitter:表示重新分布 Grid 控件的列间距或行间距的控件. ****************************************** ...

  7. WPF 控件专题 RadioButton详解

    1.RadioButton 介绍 RadioButton :单选按钮: **************************************************************** ...

  8. layui时间怎么设置年月日时分秒_layui-laydate时间日历控件使用方法详解

    本文实例为大家分享了laydate时间日历控件的使用方法,供大家参考,具体内容如下 此控件可使用layui或者独立版的layDate,两者初始化有些不同 在 layui 模块中使用layui.code ...

  9. Android控件之ConstraintLayout详解

    目录: 1.为什么要用ConstraintLayout? 2.ConstraintLayout有哪些缺点? 3.怎么使用ConstraintLayout. 1.为什么要用ConstraintLayou ...

最新文章

  1. MongoDB数据库(二:高级操作)
  2. ORB算法原理解读【不错】
  3. 如何用js获取外联css,内联外联CSS和JS
  4. 0121 - 开始学习 EOS 编程
  5. 用平常心去对待不平常的事
  6. linux 内核dmesg,linux內核調試kmsg,dmesg
  7. 一致性Hash(Consistent Hashing)原理剖析
  8. Ubuntu添加开机自动启动程序的方法 / 修改 Ubuntu 启动顺序
  9. Bootstrap使用后笔记
  10. elfutils cc1: all warnings being treated as errors
  11. Spring AOP看这个就够了
  12. python实现下载韩寒博客中的所有文章,在本地存储
  13. python爬楼梯问题_python解决上楼梯问题
  14. contiki CC2530 CC2430例子描述
  15. mmc0: Too large timeout requested for CMD25
  16. 阿里云:发短信工具类
  17. Windows特殊字符
  18. SysWow64和System32
  19. Codeforces Round #362 (Div. 2) B 模拟
  20. table添加一行且可编辑 vue_Vue使用AntDesign 表格可添加 可编辑行 可选择

热门文章

  1. CCPC之湘潭邀请赛
  2. 计算机专业开题报告论证记录如何写,浙江大学软件学院研究生开题报告论证流程说明...
  3. el-table在有些电脑上显示问题(表头与表体不对齐gutter列导致得)
  4. 静寂的声韵里悄然于心底溅扩出岁月的气息
  5. SQL必知必会第十八节挑战题
  6. fseek函数fread函数的用法
  7. Struts框架之转发和重定向
  8. XenCenter license
  9. 各国语言简写代码/php 获取(判断)操作系统语言
  10. ubuntu运行anaconda