 Các dữ liệu dạng phân cấp có thể được hiển thị trên các control HeaderedItemsControl như TreeViewItem hay MenuItem. Và để sử dụng Data Template cho các các kiểu dữ liệu này, bạn cần sử dụng lớp HierarchicalDataTemplate.
Các dữ liệu dạng phân cấp có thể được hiển thị trên các control HeaderedItemsControl như TreeViewItem hay MenuItem. Và để sử dụng Data Template cho các các kiểu dữ liệu này, bạn cần sử dụng lớp HierarchicalDataTemplate.
Trong bài này tôi sẽ làm một ví dụ binding dữ liệu lên TreeView và thiết lập hiển thị bằng các HierarchicalDataTemplate cho từng kiểu dữ liệu.
Đầu tiên bạn một dự án với tên HierarchicalBinding và tạo dữ liệu nguồn trong code-behind như sau:
| usingSystem.Windows;usingSystem.Collections.Generic;namespaceHierarchicalBinding{    publicpartialclassWindow1 : Window    {        publicWindow1()        {            InitializeComponent();            var categories = newList            var cat1 = newCategory()  CategoryName = "Antivirus";            cat1.Products.Add(newProduct()  ProductID = 1, ProductName = "Norton AV");            cat1.Products.Add(newProduct()  ProductID = 2, ProductName = "Kaspersky");            cat1.Products.Add(newProduct()  ProductID = 3, ProductName = "AVG");            var cat2 = newCategory()  CategoryName = "Browser";            cat2.Products.Add(newProduct()  ProductID = 4, ProductName = "Firefox");            cat2.Products.Add(newProduct()  ProductID = 5, ProductName = "Chrome");            cat2.Products.Add(newProduct()  ProductID = 6, ProductName = "Opera");            var cat3 = newCategory()  CategoryName = "Game";            cat3.Products.Add(newProduct()  ProductID = 7, ProductName = "FreeCell");            cat3.Products.Add(newProduct()  ProductID = 8, ProductName = "Hearts");            cat3.Products.Add(newProduct()  ProductID = 9, ProductName = "Minesweeper");            categories.Add(cat1);            categories.Add(cat2);            categories.Add(cat3);            this.DataContext = categories;        }    }    publicclassProduct    {        publicstringProductName  get; set;         publicintProductID  get; set;     }    publicclassCategory    {        publicstringCategoryName  get; set;         publicListget; set;         publicCategory()        {            Products = newList        }    }} | 
Trong Window1.xaml, ta binding dữ liệu vào TreeViewItem thông qua property ItemSource với header hiển thị là Categories. Đồng thời tạo một HierarchicalDataTemplate dùng cho kiểu dữ liệu Category trong Window.Resources. Bạn cần ItemsSource của HierarchicalDataTemplate đến collection của cấp dữ liệu tiếp theo, ở đây là Category.Products.
| <Windowx:Class="HierarchicalBinding.Window1"        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"        xmlns:local="clr-namespace:HierarchicalBinding"        Title="Hierarchical Binding Demo"Height="250"Width="300">    <Window.Resources>        <HierarchicalDataTemplateDataType="x:Type local:Category"      ItemsSource="Binding Path=Products">            <TextBlockBackground="LightBlue"Text="Binding Path=CategoryName"/>        HierarchicalDataTemplate>    Window.Resources>    <Grid>        <TreeView>            <TreeViewItemItemsSource="Binding"Header="Categories"/>        TreeView>    Grid>Window> | 
Kết quả:

Như bạn thấy các node lá trong TreeView trên đại diện cho các đối tượng Product và chúng hiển thị theo tên kiểu. Để thiết lập lại kiểu hiển thị của các node này, bạn cần tạo thêm một HierarchicalDataTemplate cho kiểu Product. Bởi vì kiểu Product không chứa collection con nào, bạn không cần gán giá trị cho ItemsSource, hay có thể dùng cú pháp ItemsSource=”Binding”:
| <Windowx:Class="HierarchicalBinding.Window1"        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"        xmlns:local="clr-namespace:HierarchicalBinding"        Title="Hierarchical Binding Demo"Height="250"Width="300">    <Window.Resources>        <HierarchicalDataTemplateDataType="x:Type local:Category"      ItemsSource="Binding Path=Products">            <TextBlockBackground="LightBlue"Text="Binding Path=CategoryName"/>        HierarchicalDataTemplate>        <HierarchicalDataTemplateDataType="x:Type local:Product">            <StackPanelOrientation="Horizontal">                <TextBlockText="Binding Path=ProductID"/>                <TextBlockText=" - "/>                <TextBlockText="Binding Path=ProductName"/>            StackPanel>        HierarchicalDataTemplate>    Window.Resources>    <Grid>        <TreeView>            <TreeViewItemItemsSource="Binding"Header="Categories"/>        TreeView>    Grid>Window> | 
Kết quả:

 
Không có nhận xét nào:
Đăng nhận xét