当前位置: 首页 > 编程笔记 >

C# WPF ListView控件的实例详解

储俊英
2023-03-14
本文向大家介绍C# WPF ListView控件的实例详解,包括了C# WPF ListView控件的实例详解的使用技巧和注意事项,需要的朋友参考一下

C# WPF ListView控件的实例详解

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#事件实例详解,包括了C#事件实例详解的使用技巧和注意事项,需要的朋友参考一下 C#事件实例详解 C#和JAVA有许多相似的地方,设计思想差不多,语法及其相像,均传承自面向对象设计思想,灵感来自C++并取其精华去其“糟粕(二字持保留意见)”,中间语言、解释执行、一次编译、到处执行,出身豪门算得上是表兄弟关系,各自拥有庞大的拥趸,两种语言在发展的道路上你追我赶相互借鉴相互学习相互渗透

  • 本文向大家介绍Android控件拖动实例详解,包括了Android控件拖动实例详解的使用技巧和注意事项,需要的朋友参考一下 Android控件拖动 Android控件的拖动,主要是通过设置控件的setOnTouchListener()方法,重写它的onTouch()方法。然后通过MotionEvent的不同事件,进行判断,主要是在MotionEvent.ACTION_MOVE中不断重绘控件在画布中

  • 本文向大家介绍AngularJS自定义控件实例详解,包括了AngularJS自定义控件实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了AngularJS自定义控件。分享给大家供大家参考,具体如下: 自定义指令介绍 AngularJS 指令作用是在 AngulaJS 应用中操作 Html 渲染。比如说,内插指令 ( {{ }} ), ng-repeat 指令以及 ng-if 指令。

  • 本文向大家介绍C#分屏控件用法实例,包括了C#分屏控件用法实例的使用技巧和注意事项,需要的朋友参考一下 本文实例中的自定义类PictureBox继承于UserControl,最终实现简单的分屏功能。分享给大家供大家参考之用。具体实现代码如下: 希望本文所述实例对大家C#程序设计有所帮助。

  • 本文向大家介绍laypage分页控件使用实例详解,包括了laypage分页控件使用实例详解的使用技巧和注意事项,需要的朋友参考一下 在开发的时候经常遇到分页比较麻烦,尤其对于一个后端程序猿来说,但是这个问题不能不解决,于是找了一个分页的控件用用,记录在下,以便以后使用。 以下是官网中使用的简单例子: 一个基本的分页效果也就出来了。 如果你需要其他更加绚丽的效果请修改源代码。 先来说下,如果呈现出来

  • 本文向大家介绍C#的File类实现文件操作实例详解,包括了C#的File类实现文件操作实例详解的使用技巧和注意事项,需要的朋友参考一下 C#对文件的操作相当方便,主要涉及到四个类:File、FileInfo、Directory、DirectoryInfo,前两个提供了针对文件的操作,后两个提供了针对目录的操作,类图关系如下: 本文举例详述了File类的用法。File中提供了许多的静态方法,使用这些