首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

绑定到ObservableCollection但不能绑定到ListCollectionView

ObservableCollection和ListCollectionView是.NET Framework中的两个常用类,用于在WPF应用程序中实现数据绑定。

ObservableCollection是一个实现了INotifyCollectionChanged接口的动态集合类,它可以自动通知绑定源的变化。当ObservableCollection中的元素发生增加、删除、移动或重置时,它会自动触发CollectionChanged事件,从而通知绑定源进行更新。

ListCollectionView是CollectionView的一个具体实现,它提供了对ObservableCollection的排序、过滤和分组等功能。ListCollectionView可以作为ObservableCollection的视图,通过设置CollectionViewSource的Source属性来实现。

在WPF中,可以将ObservableCollection直接绑定到ItemsControl、DataGrid等控件的ItemsSource属性,从而实现数据的展示和更新。例如:

代码语言:txt
复制
ObservableCollection<string> myCollection = new ObservableCollection<string>();
myCollection.Add("Item 1");
myCollection.Add("Item 2");
myCollection.Add("Item 3");

// XAML中的数据绑定
<ListBox ItemsSource="{Binding myCollection}" />

// 代码中的数据绑定
myListBox.ItemsSource = myCollection;

然而,ListCollectionView并不能直接绑定到控件的ItemsSource属性。如果想要使用ListCollectionView进行排序、过滤或分组,需要通过CollectionViewSource来创建一个ListCollectionView,并将其作为ItemsSource绑定到控件。例如:

代码语言:txt
复制
ObservableCollection<string> myCollection = new ObservableCollection<string>();
myCollection.Add("Item 1");
myCollection.Add("Item 2");
myCollection.Add("Item 3");

CollectionViewSource myCollectionViewSource = new CollectionViewSource();
myCollectionViewSource.Source = myCollection;

// 使用ListCollectionView进行排序
ListCollectionView myListView = (ListCollectionView)myCollectionViewSource.View;
myListView.SortDescriptions.Add(new SortDescription("PropertyName", ListSortDirection.Ascending));

// XAML中的数据绑定
<ListBox ItemsSource="{Binding Source={StaticResource myCollectionViewSource}}" />

// 代码中的数据绑定
myListBox.ItemsSource = myCollectionViewSource.View;

综上所述,ObservableCollection可以直接绑定到控件的ItemsSource属性,而ListCollectionView需要通过CollectionViewSource来创建并绑定。ObservableCollection适用于简单的数据展示和更新,而ListCollectionView适用于复杂的排序、过滤和分组需求。

腾讯云相关产品和产品介绍链接地址:

  • 腾讯云云服务器(CVM):https://cloud.tencent.com/product/cvm
  • 腾讯云云数据库 MySQL 版:https://cloud.tencent.com/product/cdb_mysql
  • 腾讯云对象存储(COS):https://cloud.tencent.com/product/cos
  • 腾讯云人工智能:https://cloud.tencent.com/product/ai
  • 腾讯云物联网平台:https://cloud.tencent.com/product/iotexplorer
  • 腾讯云移动开发平台(MTP):https://cloud.tencent.com/product/mtp
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • win10 uwp 如何使用DataTemplate 转换绑定Event到Command绑定 ObservableCollectionDataTemplate 绑定 ViewM

    这是数据模板,一般用在数组的绑定,显示数组中的元素。 假如我们有一个列表,列表里是书,包括书名、作者、还有出版,那么我们只有源信息,如何把它显示到我们的ListView,就需要DataTemplate。 使用很简单,我们可以定义在资源,也可以定义在ItemTemplate。 数据模板有绑定的问题。 我们使用Binding和WPF其实没有多少不同,在Mode只有OneWay,OneTime,TwoWay。我们使用的x:bind在DataTemplate才和原来有一些不同。 我们使用x:bind需要我们对我们数据的类型,这个在前没有,我开始不知,弄了好久,最后才知道,还有一个,UWP默认是OneTime,也就是绑定只有一次。

    02

    WPF Binding学习(四) 绑定各种数据源

    在这里我们使用了ListView控件和GridView控件来显示数据,这两个控件从表面来看应该属于同一级别的控件。实际上并非如此!ListView是ListBox的派生类,而GridView是ViewBase的派生类,ListView中的View是一个ViewBase对象,所以,GridView可以做为ListView的View来使用而不能当作独立的控件来使用。这里使用理念是组合模式,即ListView由一个View,但是至于是GridVIew还是其它类型的View,由程序员自己选择。其次,GridView的内容属性是Columns,这个属性是GridViewColumnCollection类型对象。因为XAML支持对内容属性的简写,可以省略<GridView.Columns>这层标签,直接在GridView内部定义<GridViewColumn>对象,GridViewColumn中最重要的一个属性是DisplayBinding(类型是BindingBase),使用这个属性可以指定这一列使用什么样的Binding去关联数据-----这与ListBox有些不同,ListBox使用的是DisplayMemberPath属性(类型是String)。如果想用更复杂的结构来表示这一标题或数据,则可为GridViewColumn设置Head Template和Cell Template,它们的类型都是DataTemplate

    03
    领券