欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來(lái)到入門(mén)教程網(wǎng)!

C#教程

當(dāng)前位置:主頁(yè) > 軟件編程 > C#教程 >

C# WPF ListView控件的實(shí)例詳解

來(lái)源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:C#教程|點(diǎn)擊: 次

C# WPF ListView控件的實(shí)例詳解

C#的WPF作為現(xiàn)在微軟主流的桌面程序開(kāi)發(fā)平臺(tái),相比過(guò)去的MFC時(shí)代,有了非常多的不同。本人剛從MFC平臺(tái)轉(zhuǎn)過(guò)來(lái),以為可以輕松上手,哪知碰到了很多問(wèn)題,十分不解。不得不乖乖回去看了本書(shū),再繼續(xù)回到邊左邊邊學(xué)的路上。在這邊也推薦《深入淺出WPF》這本書(shū),拿來(lái)上手還是極好的。

    由于WPF以數(shù)據(jù)驅(qū)動(dòng)UI的設(shè)計(jì)理念,很多控件用起來(lái)都與之前平臺(tái)的相差很多,ListView控件算是有代表性的,這是進(jìn)化的成果。關(guān)于該控件的應(yīng)該,很多參考了這篇博文,如覺(jué)本人記述不清楚,可去查閱。

    WPF的代碼分為前端和后端兩部分,前端為UI,負(fù)責(zé)與用戶進(jìn)行交互;而后端則負(fù)責(zé)算法和數(shù)據(jù)的執(zhí)行。由于這種機(jī)制,我們程序員對(duì)兩端都需要有一個(gè)大概的了解,且主要注重于后端,這點(diǎn)相比以前混起來(lái)的機(jī)制實(shí)在是好太多。

    ListView控件的XAML代碼大致如下書(shū)寫(xiě):

<ListView x:Name="listView" Height="165" VerticalAlignment="Top" HorizontalAlignment="Left" Width="604" BorderThickness="0,0,0,1" BorderBrush="#FFC8CCD4"> 
  <ListView.View> 
    <!--設(shè)置列標(biāo)簽并將列成員與一個(gè)變量名稱相綁定,以便后臺(tái)鏈接修改--> 
    <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è)O(shè)置了一個(gè)四列,列項(xiàng)分別為“姓名”、“工作年限”、“工作電話”和“郵箱”的列表,并將各項(xiàng)的成員分別與一個(gè)變量名稱相綁定。單單寫(xiě)這些代碼就已經(jīng)可以看到界面上有一個(gè)對(duì)應(yīng)的列表出現(xiàn),且可以編譯運(yùn)行。前端的工作也大致結(jié)束(定義出控件大致外觀和給出綁定接口),具體數(shù)據(jù)內(nèi)容,可交給后端來(lái)綁定。

    接下來(lái)我們來(lái)寫(xiě)后端的c#代碼:

    先定義一個(gè)類,這個(gè)類中的變量將與上面列表項(xiàng)綁定的變量一一對(duì)應(yīng),這樣我們實(shí)例化一個(gè)對(duì)象便將對(duì)應(yīng)于列表的一行。

class personalInfo//個(gè)人信息類 
{ 
  private string _name; 
  private int _workYears; 
  private string _workPhoneNumber; 
  private string _email; 
  public string Email//get和set分別為只讀和只寫(xiě),這是綁定的正常寫(xiě)法,Email為我們要進(jìn)行綁定的一個(gè)屬性 
  { 
    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)//構(gòu)造函數(shù) 
  { 
    _name = name; 
    _workYears = workYears; 
    _workPhoneNumber = workPhoneNumber; 
    _email = email; 
  } 
} 

    定義了上面的類之后,我們?cè)诖a中使用System.Collections.ObjectModel這個(gè)命名空間,然后使用“ObervableCollection”即“動(dòng)態(tài)數(shù)據(jù)集合類”來(lái)管理我們的類對(duì)象。

ObservableCollection<personalInfo> personalInfoList = new ObservableCollection<personalInfo>(); 

    之后,給數(shù)據(jù)集合添加類成員

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")); 

    最后,把數(shù)據(jù)和UI綁定在一起便大功告成了

listView.ItemsSource = personalInfoList; 

    上面的代碼編譯之后便能看到列表框和里面的數(shù)據(jù),由于“ObervableCollection”在數(shù)據(jù)添加和刪除的時(shí)候后發(fā)送消息給UI,所以我們?cè)谔砑雍蛣h除一項(xiàng)數(shù)據(jù)的時(shí)候UI會(huì)做相應(yīng)的修改。然而如果修改類里面的內(nèi)容的時(shí)候則不行,因?yàn)樾薷牡臅r(shí)候沒(méi)有發(fā)送消息通知UI,所以我們還需要給“personalInfo”類定義消息通知接口,讓其數(shù)據(jù)發(fā)生改變的時(shí)候也給UI發(fā)送消息。該類修改如下(需要添加System.ComponentModel命名空間):

class personalInfo: INotifyPropertyChanged //個(gè)人信息類 
{ 
  private string _name; 
  private int _workYears; 
  private string _workPhoneNumber; 
  private string _email; 
 
  public event PropertyChangedEventHandler PropertyChanged; 
 
  public string Email//get和set為只讀和只寫(xiě),體現(xiàn)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)//構(gòu)造函數(shù) 
  { 
    _name = name; 
    _workYears = workYears; 
    _workPhoneNumber = workPhoneNumber; 
    _email = email; 
  } 
} 

    這樣,我們便實(shí)現(xiàn)了ListView控件的基本綁定、修改和顯示功能了。

如有疑問(wèn)請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

上一篇:C#編寫(xiě)Windows服務(wù)程序詳細(xì)步驟詳解(圖文)

欄    目:C#教程

下一篇:WPF TextBox水印效果制作方法詳解

本文標(biāo)題:C# WPF ListView控件的實(shí)例詳解

本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/5476.html

網(wǎng)頁(yè)制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語(yǔ)言數(shù)據(jù)庫(kù)服務(wù)器

如果侵犯了您的權(quán)利,請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有