SilverLight-DataBinding-DataTemplates: 三、数据绑定 DataTemplates模板的使用(求助,没有到达实例效果,求高人指点迷津)

简介:
ylbtech-SilverLight-DataBinding-DataTemplates: 三、数据绑定 DataTemplates模板的使用
  • 1.A, Data Templates Intro(数据模板说明)
  • 1.B, Separating and Resuing Templates(分离和复用模板)
  • 1.C, More Advanced Templates(更先进的模板)
  • 1.D, Changing Items Layout(改变项目布局)

测试数据地址:http://www.cnblogs.com/ylbtech/p/3434972.html 的“1.A, Product.cs 产品类”

1.A, Data Templates Intro(数据模板说明)返回顶部
1,
最好的方式来了解数据模板的工作原理是首先基本列表,不 使用一个模板。 例如,考虑这个列表框,这是先前所显示的:
<ListBox Name="lstProducts" DisplayMemberPath="ModelName"></ListBox>

你可以得到同样的效果和这个列表框,使用一个数据模板:

复制代码
<ListBox Name="lstProducts">
    <ListBox.ItemTemplate>
        <DataTemplate>
            <TextBlock Text="{Binding ModelName}"></TextBlock>
        </DataTemplate>
    </ListBox.ItemTemplate>
</ListBox>
复制代码

 4,

1.B, Separating and Reusing Templates(分离和重用模板)返回顶部
1,图片
1.1, 目标效果图
1.2, 实际效果图
2,
2.1/3,[无]
2.2/3,
  View Code

2.3/3,

  View Code

3,代码摘要

复制代码
<ListBox Grid.Row="1" Name="lstProduct" Margin="3" HorizontalContentAlignment="Stretch" SelectionChanged="lstProduct_SelectionChanged">
    <ListBox.ItemTemplate>
        <DataTemplate>
                <Border>
                    <Border Margin="5" BorderBrush="SteelBlue" BorderThickness="1" CornerRadius="4">
                <Grid Margin="3">
                    <Grid.RowDefinitions>
                        <RowDefinition Height="Auto"></RowDefinition>
                        <RowDefinition Height="Auto"></RowDefinition>
                    </Grid.RowDefinitions>
                    <TextBlock Grid.Row="0" Text="{Binding ProductId}" FontWeight="Bold"></TextBlock>
                    <TextBlock Grid.Row="1" Text="{Binding ProductName}"></TextBlock>
                </Grid>
            </Border>
                </Border>
            </DataTemplate>
    </ListBox.ItemTemplate>
</ListBox>
复制代码

4,



1.C, More Advanced Templates(更先进的模板)返回顶部

1, 图片
1.1, 目标效果图
1.2, 实际效果图
2,
2.1/3,[无]
2.2/3,
  View Code

2.3/3, 代码同上 1.B.2.3/3

3, 代码摘要
3.1/2,  做这个工作,你所需要做的是定义你的数据模板在一个资源 收集和给它一个键名。 这里的一个例子,提取模板所示 前面的示例:
复制代码
<UserControl.Resources>
    <!--数据模板 begin-->
    <DataTemplate x:Key="ProductDataTemplate">
        <Border>
            <Border Margin="5" BorderBrush="SteelBlue" BorderThickness="1" CornerRadius="4">
                <Grid Margin="3">
                    <Grid.RowDefinitions>
                        <RowDefinition Height="Auto"></RowDefinition>
                        <RowDefinition Height="Auto"></RowDefinition>
                        <RowDefinition Height="Auto"></RowDefinition>
                    </Grid.RowDefinitions>
                    <TextBlock Grid.Row="0" Text="{Binding ProductId}" FontWeight="Bold"></TextBlock>
                    <TextBlock Grid.Row="1" Text="{Binding ProductName}"></TextBlock>
                    <Image  Grid.Row="2" Source="{Binding ProductImagePath}"></Image>
                </Grid>
            </Border>
        </Border>
    </DataTemplate>
    <!--数据模板 end-->
</UserControl.Resources>
复制代码

3.2/2,现在你可以使用你的数据模板使用StaticResource参考:

<!--ListBox 使用数据模板-->
<ListBox Grid.Row="1" Name="lstProduct" Margin="3" HorizontalContentAlignment="Stretch" 
            SelectionChanged="lstProduct_SelectionChanged" ItemTemplate="{StaticResource ProductDataTemplate}">
</ListBox>

 4,

1.D, Changing Items Layout(改变项目布局)返回顶部
1, 图片
1.1, 目标效果图
1.2, 实际效果图
2,
2.1/3,
xmlns:controlsToolkit="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Toolkit"

2.2/3,

  View Code

2.3/3, 代码同上 1.B.2.3/3

3, 代码摘要
数据模板给你非凡的控制各方面的项目演示。 然而, 他们不允许你改变项目组织与尊重对方。 没有 不管你使用的模板和样式,列表框将每个项目到一个单独的水平 行和栈的每一行创建列表。 你可以改变这个布局取代容器列表使用奠定了 的派生。 这样做,你们设置ItemsPanel财产与一块XAML,定义了面板 你想使用。 这个小组可以是任何类,来源于系统windows控制面板, 包括一个自定义布局容器实现你自己的专业布局逻辑。
以下使用WrapPanel从Silverlight Toolkit (http://www.codeplex.com/Silverlight),这是在第三章描述。 它安排项目 从左到右的多个行:
复制代码
<!--ListBox 使用数据模板-->
<ListBox Grid.Row="1" Name="lstProduct" Margin="3" HorizontalContentAlignment="Stretch"
            SelectionChanged="lstProduct_SelectionChanged" ItemTemplate="{StaticResource ProductDataTemplate}">
    <ListBox.ItemsPanel>
        <ItemsPanelTemplate>
            <controlsToolkit:WrapPanel></controlsToolkit:WrapPanel>
        </ItemsPanelTemplate>
    </ListBox.ItemsPanel>
</ListBox>
复制代码

4,

1.E, 参考资料返回顶部
 
[Silverlight.3.高级编程(C#篇)].Apress.Pro.Silverlight.3.in.C.Sharp.Oct.2009

本文转自ylbtech博客园博客,原文链接:http://www.cnblogs.com/ylbtech/p/3433757.html ,如需转载请自行联系原作者
 
相关文章

热门文章

最新文章