如何让 WPF 中 ListBox 列表项前自动加上序号

有时候我们可以希望在 ListBox 列表项前面加上序号,这样看起来更清楚,还可以配合使用快捷键等。

希望达到如下图的效果:

显然我们可以通过修改 ListBox 的模板来实现,只要在 Item 中加上数字这一项即可,利用 MultiBinding 和 IMultiValueConverter 即可实现。

示例

首先,我们创建一个 Person 类:

public class Person
{
    public string Name { get; set; }
}

然后创建一个 Converter,继承自 IMultiValueConverter:

注意第 5~6 行,使用了 dynamic 类型,所以必须保证 list 有 IndexOf 这个扩展方法,IEnumerable<T> 是不行的。

public class IndexConverter : IMultiValueConverter
{
    public object Convert( object[] values, Type targetType, object parameter, CultureInfo culture)
    {
        dynamic item = values[0];
        dynamic list = values[1];
        return list.IndexOf(person) + 1;
    }

    public object[] ConvertBack( object value, Type[] targetTypes, object parameter, CultureInfo culture)
    {
        throw new NotImplementedException ();
    }
}

 

XAML 如下:

关键在于 17~20 行,分别绑定了单项数据和 ListBox 本身。

<Window x:Class="ListBoxIndex.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:listBoxIndex ="clr-namespace:ListBoxIndex"
        Title="MainWindow" Height ="350" Width="525">
    <Window.Resources>
        <listBoxIndex: IndexConverter x:Key="IndexConverter"/>
    </Window.Resources>
    <StackPanel >
        <Button Name="BtnDemo" Content="Add" Click="BtnDemo_OnClick"/>
        <ListBox Name="LbxDemo">
            <ListBox.ItemTemplate>
                <DataTemplate DataType="listBoxIndex:Person">
                    <StackPanel Orientation="Horizontal">
                        <TextBlock Text="{Binding}">
                            <TextBlock.DataContext>
                                <MultiBinding Converter="{StaticResource IndexConverter }">
                                    <Binding/>
                                    <Binding ElementName="LbxDemo" Path="ItemsSource"/>
                                </MultiBinding>
                            </TextBlock.DataContext>
                        </TextBlock>
                        <TextBlock Text="{Binding Name}"/>
                    </StackPanel>
                </DataTemplate>
            </ListBox.ItemTemplate>
        </ListBox>
    </StackPanel >
</Window>

代码如下:

namespace ListBoxIndex
{
    /// <summary>
    /// MainWindow.xaml 的交互逻辑
    /// </summary>
    public partial class MainWindow : Window
    {
        readonly ObservableCollection <Person> _personList = new ObservableCollection <Person>();

        public MainWindow()
        {
            InitializeComponent();
            InitSource();
        }

        private void InitSource()
        {
            _personList.Add(new Person() {Name = "刘备" });
            _personList.Add(new Person() {Name = "关羽" });

            LbxDemo.ItemsSource = _personList;
        }

        private void BtnDemo_OnClick( object sender, RoutedEventArgs e)
        {
            _personList.Add(new Person() {Name = "张飞" });
            LbxDemo.ItemsSource = _personList;
        }
    }
}

  

 

转载于:https://www.cnblogs.com/fujinxiang/p/ListBoxIndex.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值