博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
WPF中实现多选ComboBox控件
阅读量:5060 次
发布时间:2019-06-12

本文共 2998 字,大约阅读时间需要 9 分钟。

原文:

在WPF中实现带CheckBox的ComboBox控件,让ComboBox控件可以支持多选。

将ComboBox的ItemsSource属性Binding到一个Book的集合,

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

显示效果如下:

为了让ComboBox支持CheckBox,和上面代码一样,修改ComboBox的DataTemplate,CheckBox的选中/非选中状态需要Binding到一个Bool型的Property上面。但是这个Property并不是Book的一个属性,所以新建一个BookEx类,增加一个IsChecked属性

public class BookEx : ObservableObject    {        public Book Book { get; private set; }        private bool _isChecked;        public bool IsChecked        {            get            {                return _isChecked;            }            set            {                if(_isChecked != value)                {                    _isChecked = value;                    RaisePropertyChanged("IsChecked");                }            }        }        public BookEx(Book book)        {            Book = book;        }    }

将ComboBox的ItemsSource属性Binding到BookEx集合上,下面修改ComboBox的DataTemplate:

此时已经可以实现多选了,但是当选择相应的条目后,在ComboBox的Text区域并不显示。下面来解决这个问题。实现方式是将选中的Book的Name属性集合Binding到ComboBox的Text属性上面。对ViewModel做一些改造,增加一个SelectedText属性,用来显示选中的条目Name集合

public ObservableCollection
BookExs{ get { if(_books == null) { _books = new ObservableCollection
(); _books.CollectionChanged += (sender, e) => { if(e.OldItems != null) { foreach (BookEx bookEx in e.OldItems) { bookEx.PropertyChanged -= ItemPropertyChanged; } } if(e.NewItems != null) { foreach (BookEx bookEx in e.NewItems) { bookEx.PropertyChanged += ItemPropertyChanged; } } }; } return _books; }}private void ItemPropertyChanged(object sender, PropertyChangedEventArgs e){ if(e.PropertyName == "IsChecked") { BookEx bookEx = sender as BookEx; if(bookEx != null) { IEnumerable
bookExs = BookExs.Where(b => b.IsChecked == true); StringBuilder builder = new StringBuilder(); foreach (BookEx item in bookExs) { builder.Append(item.Book.Name + " "); } SelectedText = builder == null ? string.Empty : builder.ToString(); } }}

最后一个注意点,修改ComboBox的IsEditable="True",只有这样才能接收Text的Binding。

实现的效果如下:

 就这样一个可以多选的ComboBox就实现了。代码点击下载。

感谢您的阅读,如果您有其他实现方式,欢迎在评论区域点评,谢谢~

posted on
2018-11-12 14:26 阅读(
...) 评论(
...)

转载于:https://www.cnblogs.com/lonelyxmas/p/9946250.html

你可能感兴趣的文章
发送请求时params和data的区别
查看>>
JavaScript 克隆数组
查看>>
eggs
查看>>
一步步学习微软InfoPath2010和SP2010--第七章节--从SP列表和业务数据连接接收数据(4)--外部项目选取器和业务数据连接...
查看>>
如何增强你的SharePoint 团队网站首页
查看>>
FZU 1914 Funny Positive Sequence(线性算法)
查看>>
oracle 报错ORA-12514: TNS:listener does not currently know of service requested in connec
查看>>
基于grunt构建的前端集成开发环境
查看>>
MySQL服务读取参数文件my.cnf的规律研究探索
查看>>
java string(转)
查看>>
__all__有趣的属性
查看>>
写博客
查看>>
利用循环播放dataurl的视频来防止锁屏:NoSleep.js
查看>>
python3 生成器与迭代器
查看>>
java编写提升性能的代码
查看>>
ios封装静态库技巧两则
查看>>
Educational Codeforces Round 46 (Rated for Div. 2)
查看>>
Abstract Factory Pattern
查看>>
C# 实现Bresenham算法(vs2010)
查看>>
基于iSCSI的SQL Server 2012群集测试(一)--SQL群集安装
查看>>