前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >WPF ListBox 的选择

WPF ListBox 的选择

作者头像
林德熙
发布2018-09-18 15:40:46
2K0
发布2018-09-18 15:40:46
举报
文章被收录于专栏:林德熙的博客

本文告诉大家在 ListBox 做选择时,多选时 SelectedItem 和 SelectedIndex 的值。

首先写一个界面,两个按钮和一个ListBox ,点击第一个按钮选择多个元素,点击第二个按钮就显示当前的 SelectedItem 和 SelectedIndex

代码语言:javascript
复制
    <Grid>
        <ListBox x:Name="QjdckjpVemnepybg" SelectionMode="Multiple"></ListBox>
        <Button Width="100" Height="100" Click="ButtonBase_OnClick"></Button>
        <Button Margin="100,10,10,10" Width="100" Height="100" Click="RyltnqiUmqgwuz_OnClick"></Button>
    </Grid>

在点击前需要给 ListBox 数据,请看下面

代码语言:javascript
复制
        public MainWindow()
        {
            InitializeComponent();
            QjdckjpVemnepybg.ItemsSource = FyuzbqklBxdk;

            for (int i = 0; i < 100; i++)
            {
                FyuzbqklBxdk.Add(i.ToString());
            }
        }

        public ObservableCollection<string> FyuzbqklBxdk { get; } = new ObservableCollection<string>();

点击第一个按钮选择多个元素

代码语言:javascript
复制
        private void ButtonBase_OnClick(object sender, RoutedEventArgs e)
        {
            QjdckjpVemnepybg.SelectedItems.Clear();
            QjdckjpVemnepybg.SelectedItems.Add(FyuzbqklBxdk[2]);
            QjdckjpVemnepybg.SelectedItems.Add(FyuzbqklBxdk[5]);
        }

点击第二个按钮显示 SelectedItem 和 SelectedIndex

代码语言:javascript
复制
        private void RyltnqiUmqgwuz_OnClick(object sender, RoutedEventArgs e)
        {
            Console.WriteLine(QjdckjpVemnepybg.SelectedItem);
            Console.WriteLine(QjdckjpVemnepybg.SelectedIndex);
        }

可以看到,点击第一个按钮之后,SelectedItem 和 SelectedIndex 都是 2 因为他会显示多选的第一个。

如果选择的是 SelectedItem ,那么 SelectedItems 就只有 SelectedItem 的元素

代码语言:javascript
复制
      private void ButtonBase_OnClick(object sender, RoutedEventArgs e)
        {
            QjdckjpVemnepybg.SelectedItem = FyuzbqklBxdk[2];
        }

        private void RyltnqiUmqgwuz_OnClick(object sender, RoutedEventArgs e)
        {
            Console.WriteLine(QjdckjpVemnepybg.SelectedItems.Count);
            foreach (var temp in QjdckjpVemnepybg.SelectedItems)
            {
                Console.WriteLine(temp);
            }
        }

如果选择是 SelectedIndex ,那么 SelectedItems 有对应序号的元素

代码语言:javascript
复制
    private void ButtonBase_OnClick(object sender, RoutedEventArgs e)
        {
            QjdckjpVemnepybg.SelectedIndex = 2;
        }

        private void RyltnqiUmqgwuz_OnClick(object sender, RoutedEventArgs e)
        {
            Console.WriteLine(QjdckjpVemnepybg.SelectedItems.Count);
            foreach (var temp in QjdckjpVemnepybg.SelectedItems)
            {
                Console.WriteLine(temp);
            }
        }

如果这时 SelectedIndex 为 -1 ,那么 SelectedItems 没有选择元素

代码语言:javascript
复制
        private void ButtonBase_OnClick(object sender, RoutedEventArgs e)
        {
            QjdckjpVemnepybg.SelectedIndex = -1;
        }

        private void RyltnqiUmqgwuz_OnClick(object sender, RoutedEventArgs e)
        {
            Console.WriteLine(QjdckjpVemnepybg.SelectedItems.Count);
            foreach (var temp in QjdckjpVemnepybg.SelectedItems)
            {
                Console.WriteLine(temp);
            }
        }

如果这时的 SelectedItems 没有选择元素,那么 SelectedIndex 是 -1

如果这时没有开启多选,那么在 SelectedItem 选中元素时,SelectedItems 只有他选中的。所以一般可以通过 SelectedItems 判断当前选中的。


本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档