zoukankan      html  css  js  c++  java
  • WPF : ListBox的几种Template属性

    属性名 属性的类名 功能 示例
    Template ControlTemplate 定义控件自身的外观.

    其子元素的布局可以自定义,也可以由ItemsPresenter定义.

    <Style TargetType="ListBox"> 
    <Setter Property="Template"> 
    <Setter.Value> 
    <ControlTemplate TargetType="ListBox"> 
    <Border> 
    <ScrollViewer> 
    <StackPanel IsItemsHost="True"/> 
    </ScrollViewer> 
    </Border> 
    </ControlTemplate> 
    </Setter.Value> 
    </Setter> 
    </Style>

    IsItemsHost=true表示子元素将显示在此容器中.此处StackPanel也可以用<ItemsPresenter/>代替.
    ItemsPanel ItemsPanelTemplate 定义子元素的布局, 其内容为StackPanel, Grid, WrapPanel, DockPanel等布局容器.

    ItemsPresenter会创建该属性指定的布局容器
    <Style TargetType="ListBox"> 
    <Setter Property="ItemsPanel"> 
    <Setter.Value> 
    <ItemsPanelTemplate> 
    <StackPanel Orientation="Horizontal"  VerticalAlignment="Center" HorizontalAlignment="Center"/> </ItemsPanelTemplate>
     
    </Setter.Value> 
    </Setter> 
    </Style>
    ItemTemplate DataTemplate 定义每个子元素的外观.

    这个值会拷贝给ListBoxItem的ContentTemplate属性

    <ListBox> 
    <ListBox.ItemTemplate> 
    <DataTemplate> 
    <StackPanel> 
    <TextBlock Text="{Binding Path=TaskName}" /> <TextBlock Text="{Binding Path=Description}"/> <TextBlock Text="{Binding Path=Priority}"/> </StackPanel> 
    </DataTemplate>
     
    </ListBox.ItemTemplate> </ListBox>

     WPF_Template

    一起使用:

    <Style TargetType="{x:Type ListBox}">

    <!-- 定义每个子元素的外观, 显示每个子元素的数据 -->
    <Setter Property="ItemTemplate"> 
    <Setter.Value> 
    <DataTemplate> 
    <StackPanel> 
    <TextBlock Text="{Binding Path=TaskName}" /> 
    <TextBlock Text="{Binding Path=Description}"/> 
    <TextBlock Text="{Binding Path=Priority}"/> </StackPanel> 
    </DataTemplate>
     
    </Setter.Value> 
    </Setter>

    <!-- 定义子元素的布局容器, 比如:横向,纵向 -->
    <Setter Property="ItemsPanel"> 
    <Setter.Value> 
    <ItemsPanelTemplate> 
    <StackPanel Orientation="Horizontal" VerticalAlignment="Center" HorizontalAlignment="Center"/> 
    </ItemsPanelTemplate> 
    </Setter.Value> 
    </Setter> 

    <!-- 定义ListBox自身外观, 比如: 圆角边框-->
    <Setter Property="Template"> 
    <Setter.Value> 
    <ControlTemplate TargetType="ListBox"> 
    <Border CornerRadius="5" Background="{TemplateBinding ListBox.Background}"> 
    <ScrollViewer HorizontalScrollBarVisibility="Auto"> 
    <ItemsPresenter/> 
    </ScrollViewer> 
    </Border> 
    </ControlTemplate> 
    </Setter.Value> 
    </Setter>

  • 相关阅读:
    怎么让图片居中显示?
    上传代码出现弹出框“请确保已在git中配置您的user.name和user.email”解决方法
    window.open()下载文件: 在当前页面打开方法
    修改网站颜色为黑白 (100% 灰度)/全页置灰
    ZMQ简单使用
    CCXT
    Python描述符详解
    自定义序列的修改、散列和切片
    使用__slots__类属性节省空间
    QGraphicsView实现虚拟摇杆
  • 原文地址:https://www.cnblogs.com/sjqq/p/7846360.html
Copyright © 2011-2022 走看看