微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

WPF/silverlight ItemsControl 解析

ItemsControl 是一种数据展示控件,大致分为三个部分组成:Template,ItemTemplate, ItemsPanel.

 

  1. 先说 Template ,Template 是整个控件的架构设计,最外面放什么的小编,里面放什么小编,都在这里控制,负责宏观的结构,下面这个例子:最外面是一个border,然后要放一个ScrollViewer用来滚动展示,滚动的内容,就由ItemsPresenter 来决定。对应blend菜单:右键—>Edit Template

     <ItemsControl.Template>

            <ControlTemplate  targettype="{x:Type ItemsControl}">

                <Border CornerRadius="5">

                   < ScrollViewer VerticalScrollBarVisibility="Auto" >

                       < ItemsPresenter   />

                   < /ScrollViewer>

                </Border>

            </ControlTemplate>

        </ItemsControl.Template>

2. 再说ItemsPanel,作为数据展示,总要有个容器吧,这个panel就是为了设置容器用的,设置为StackPanel,WrapPanel都可以,足够灵活,对应上一条中的ItemsPresenter,

对应blend菜单 :右键--àEdit Additional TemplatesàEdit  Layout  Items(ItemsPanel) 

 例如:

        <ItemsControl.ItemsPanel>

            <ItemsPanelTemplate>

                <WrapPanel  Name="wp"  />

            </ItemsPanelTemplate>

        </ItemsControl.ItemsPanel>

 3. 最后是ItemTemplate , 每一个数据条目应该是个什么样子,负责具体呈现的,例如数据项是一个图片,那就用图片显示

对应blend菜单 :右键--à Edit Additional TemplatesàEdit  Generated  Items(Itemstemplate) 

  <ItemsControl.ItemTemplate>

      <DataTemplate>

         <Image Source="{Binding XPath=@}" />

     </DataTemplate>

</ItemsControl.ItemTemplate>
4. 附带一个,ItemContainerStyle ,也就是控制每个数据条目的显示样式,例如,想要在上例中的Image外面加一个边框,

对应blend菜单 :右键--à Edit Additional TemplatesàEdit  Generated  Item Container (ItemContainerStyle) 

   <ItemsControl.ItemContainerStyle>

            <Style targettype="{x:Type ListBoxItem}">

                <Setter Property="Template">

                    <Setter.Value>

                        <ControlTemplate targettype="{x:Type ListBoxItem}">

                            <Border BorderBrush="Black" BorderThickness=".5" Height="100">

                                <ContentPresenter />

                            </Border>

                        </ControlTemplate>

                    </Setter.Value>

                </Setter>

            </Style>

        </ItemsControl.ItemContainerStyle>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐