婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 解析WPF綁定層次結(jié)構(gòu)數(shù)據(jù)的應(yīng)用詳解

解析WPF綁定層次結(jié)構(gòu)數(shù)據(jù)的應(yīng)用詳解

熱門標(biāo)簽:戶外地圖標(biāo)注軟件手機(jī)哪個好用 萊蕪?fù)夂綦婁N機(jī)器人價格 長春呼叫中心外呼系統(tǒng)哪家好 電銷語音自動機(jī)器人 五常地圖標(biāo)注 鄭州400電話辦理 聯(lián)通 凱立德導(dǎo)航官網(wǎng)地圖標(biāo)注 智能電話營銷外呼系統(tǒng) 地圖標(biāo)注和認(rèn)領(lǐng)

在實際項目應(yīng)用中會存在多種類型的層次結(jié)構(gòu)數(shù)據(jù),WPF提供了良好的數(shù)據(jù)綁定機(jī)制。其中運(yùn)用最頻繁的就是ListBox和TreeView控件。

一、ListBox和TreeView控件的區(qū)別
1.ListBox顯示單層次數(shù)據(jù)集合,TreeView可以顯示單層次和多層次數(shù)據(jù)集合;
2.通過ListBox在UI層面可以展示良好的數(shù)據(jù)顯示效果,對數(shù)據(jù)集合可以進(jìn)行排序、分組、過濾操作;
3.TreeView顯示為一個多層次的數(shù)據(jù)集合為樹形結(jié)構(gòu),通過Templete和Style屬性同樣可以為其定義良好的數(shù)據(jù)顯示效果;

二、ListBox控件示例
1.ListBox綁定數(shù)據(jù)進(jìn)行分組:
使用ListBox.GridStyle標(biāo)簽,定義HeaderTemplate屬性用來定義組頭的外觀:

復(fù)制代碼 代碼如下:

代碼
 ListBox ItemSource="{Binding Path=Data}">
  ListBox.GridStyle>
      GroupStyle.HeaderTemplate>
           DataTemplate>
                 Stackpanel>
                          Image Source="xxx.jpg"/>
                           Label Content="C:"/>
                  Stackpanel>
           /DataTemplate>
      /GroupStyle.HeaderTemplate>
  /ListBox.GridStyle>
 ......
  /ListBox>


這樣就可以創(chuàng)建出類似WINDOWS 文件管理器的效果:
  

2.Listbox一些使用經(jīng)驗:
/1 如果要實現(xiàn)類似WINDOWS的漂亮的界面效果并進(jìn)行分組,需要自定義GroupStyle的樣式,否則WPF會使用內(nèi)建的GroupStyle,也可以引用GroupStyle.Default靜態(tài)屬性。
/2 ListBox只能定義一層數(shù)據(jù)結(jié)構(gòu),在ListBox中的Item里再次使用ListBox,后ListBox里的ItemSource不會繼承上一層ListBox的Item源中的數(shù)據(jù)集合,如有如下數(shù)據(jù)集合:
復(fù)制代碼 代碼如下:

public ListGroups> groups = new ListGroups>();groups.Add(new Group);........

復(fù)制代碼 代碼如下:

public class Group {
        public int Id { get; set; }
        public string Name { get; set; }
        private ListBox> boxes = new ListBox>();
        public ListBox> Boxes {
            get { return boxes; }
        }
    }

Listbox的ItemSource Binding ListGroups>的數(shù)據(jù)集合,其Item中的ListBox Binding ListBox>,則Item中的ListBox是無法獲取ListBox>這個數(shù)據(jù)集合的;

三、TreeView控件示例
1.有如上數(shù)據(jù)集合,使用TreeView綁定多層數(shù)據(jù)集合:
復(fù)制代碼 代碼如下:

代碼
 TreeView x:Name="maintree" FocusVisualStyle="{x:Null}" ItemsSource="{Binding Groups}">
             TreeView.ItemContainerStyle>
                 Style TargetType="{x:Type TreeViewItem}">
                     Setter Property="IsExpanded" Value="{Binding IsExpanded, Mode=TwoWay}" />
                     Setter Property="IsSelected" Value="{Binding IsSelected, Mode=TwoWay}" />
                     Setter Property="FontWeight" Value="Normal" />
                     Style.Triggers>
                         Trigger Property="IsSelected" Value="True">
                             Setter Property="FontWeight" Value="Bold"/>
                         /Trigger>
                     /Style.Triggers>
                 /Style>
             /TreeView.ItemContainerStyle>
             TreeView.Resources>
                 HierarchicalDataTemplate DataType="{x:Type m:GroupVO}" ItemsSource="{Binding Boxes}">
                     StackPanel Orientation="Horizontal">
                         Label Content="{Binding Path=FriendlyName}">/Label>
                         CheckBox VerticalAlignment="Center" IsChecked="{Binding Path=IsSelected}">/CheckBox>
                     /StackPanel>                
                 /HierarchicalDataTemplate>              

                 DataTemplate DataType="{x:Type m:BoxVO}">
                     Grid Margin="0,5,5,10" MouseDown="maintree_MouseDown" Loaded="Grid_Loaded">
                         Grid.RowDefinitions>
                             RowDefinition>/RowDefinition>
                         /Grid.RowDefinitions>
                         Grid.ColumnDefinitions>
                             ColumnDefinition Width="*">/ColumnDefinition>
                             ColumnDefinition Width="6*">/ColumnDefinition>
                         /Grid.ColumnDefinitions>
                         Image Source="/Resources/Images/shgbit.png" Width="50" VerticalAlignment="Top" Grid.Column="0" Grid.Row="0">/Image>
                             Label Grid.RowSpan="2" Grid.Row="0" Grid.Column="0" Margin="5,5,0,0" Content="{Binding Path=FriendlyName}">/Label>
                 /DataTemplate>
             /TreeView.Resources>
         /TreeView>

HierarchicalDataTemplate屬性為層級數(shù)據(jù)模板,它繼承數(shù)據(jù)集合的層級結(jié)構(gòu),要表示樹的層級依賴關(guān)系必須使用HierarchicalDataTemplate。
屬性綁定數(shù)據(jù)使用TwoWay是為雙向?qū)傩裕?dāng)源數(shù)據(jù)或目標(biāo)被改變是更新另一方的數(shù)據(jù)。在層次樹表示中的典型應(yīng)用就是:用CheckBox進(jìn)行子節(jié)點(diǎn)的選中和未選中的狀態(tài)傳遞。

您可能感興趣的文章:
  • WPF中的ListBox實現(xiàn)按塊顯示元素的方法
  • WPF的數(shù)據(jù)綁定詳細(xì)介紹
  • WPF綁定實例詳解
  • MVVM模式下WPF動態(tài)綁定展示圖片
  • C#中WPF ListView綁定數(shù)據(jù)的實例詳解
  • WPF快速入門教程之綁定Binding
  • WPF基礎(chǔ)教程之元素綁定詳解

標(biāo)簽:西寧 岳陽 西藏 衢州 湖州 福州 宣城 紅河

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《解析WPF綁定層次結(jié)構(gòu)數(shù)據(jù)的應(yīng)用詳解》,本文關(guān)鍵詞  解析,WPF,綁定,層次,結(jié)構(gòu),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《解析WPF綁定層次結(jié)構(gòu)數(shù)據(jù)的應(yīng)用詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于解析WPF綁定層次結(jié)構(gòu)數(shù)據(jù)的應(yīng)用詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 沁源县| 汉源县| 阳江市| 家居| 天水市| 江西省| 武胜县| 达孜县| 内乡县| 手游| 阜南县| 民勤县| 唐海县| 镇赉县| 芜湖市| 黔西县| 洛宁县| 横山县| 凯里市| 玉田县| 泸溪县| 株洲县| 武乡县| 秦皇岛市| 大悟县| 东源县| 金川县| 大关县| 平远县| 新建县| 额济纳旗| 安塞县| 连州市| 隆尧县| 乌兰浩特市| 浮梁县| 万源市| 江孜县| 澳门| 靖江市| 京山县|