WPF——为ListBox的Items设置布局面板

6 篇文章 0 订阅

自定义 ListBox 的控件面板

在默认情况下,ListBox 的子项目显示类似于默认的 StackPanel,在水平方向为 Strench 垂直方向进行堆叠.

而有时候,为了控制子元素的布局方式,需要自定义 ListBox 的内部面板,例如为了实现下面的效果

Display with 2 columns
可以看到,上面采用的是双列布局,实际上用的是 UniformGrid 控件作为 ListBox 的内部面板,因此,对于绑定的数据集合,就相当于是在一个 UniformGrid 中进行放置,唯一区别的是,每个子元素的范围是其实际的占用区域,在其外部还有许多留白,这部分相当于是 ListBox 的子区域点击外侧的空白处也是可以触发 SelectedValueChanged

相关的 XAML 代码如下

<ListBox ItemsSource="{Binding Students}">
    <!--此处ItemsPanel即设置ListBox内部面板 -->
    <ListBox.ItemsPanel>
        <ItemsPanelTemplate>
            <UniformGrid Columns="2"/>
        </ItemsPanelTemplate>
    </ListBox.ItemsPanel>
    <ListBox.ItemTemplate>
        <DataTemplate>
            <Border BorderBrush="CadetBlue" BorderThickness="1" Margin="5">
                <StackPanel Orientation="Horizontal">
                    <TextBlock Text="{Binding ID,StringFormat=Student ID: {0}}" FontSize="18"/>
                    <TextBlock Text="{Binding Name,StringFormat=Name: {0}}" FontSize="18" Margin="10 0"/>
                </StackPanel>
            </Border>
        </DataTemplate>
    </ListBox.ItemTemplate>
</ListBox>

对于 ItemsControl 的进一步布局、数据绑定知识,可以参考微软官方文档 Data Templating Overview, 在该文档中可以查阅到 ItemsControl 对于数据模板 DataTemplate,控件模板 ControlTemplate 和项目面板 ItemsPanel 的详细说明

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值