如何将List <customobject>绑定到WPF DataGrid?</customobject>

时间:2011-02-13 11:54:09

标签: c# wpf data-binding datagrid

我是WPF的新手,想要做一些基本的数据绑定。 我有一个CustomObject的列表,并希望将它绑定到DataGrid。

MainWindow.xaml.cs

   using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Data;
    using System.Windows.Documents;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Imaging;
    using System.Windows.Navigation;
    using System.Windows.Shapes;

    namespace WpfApplication1
    {
        /// <summary>
        /// Interaction logic for MainWindow.xaml
        /// </summary>
        public partial class MainWindow : Window
        {
            public MainWindow()
            {
                InitializeComponent();
                List<ArticleItem> list = new List<ArticleItem>() 
                {
                new ArticleItem(){ ID=3, Title="test", ViewCount=5},
                new ArticleItem(){ ID=3, Title="test", ViewCount=5},
                new ArticleItem(){ ID=3, Title="test", ViewCount=5},
                new ArticleItem(){ ID=3, Title="test", ViewCount=5},
                };
            }
        }

        public class ArticleItem 
        {
            public int ID { get; set; }
            public int ViewCount { get; set; }
            public String Title { get; set; }
        }
    }

这就是我的网格的样子:

<DataGrid Height="179" HorizontalAlignment="Left" Margin="54,65,0,0" Name="dataGrid1" VerticalAlignment="Top" Width="382">
    <DataGrid.Columns>
        <DataGridTextColumn Header="ID"/>
            <DataGridTextColumn Header="ViewCount" />
        <DataGridTextColumn Header="Title" />
    </DataGrid.Columns>
</DataGrid>

我习惯于ASP.Net的数据绑定,我可以很容易地说:

this.dataGrid1.DataSource = list;

我如何进行WPF?

4 个答案:

答案 0 :(得分:30)

如果您不希望重新创建list,那么您可以使用与Asp.Net相同的方法(而不是DataSource WPF中的此属性通常被命名为{ {1}}):

ItemsSource

但是如果您想用新的集合实例替换this.dataGrid1.ItemsSource = list; ,那么您应该考虑使用list

答案 1 :(得分:20)

您应该在xaml代码中执行此操作:

<DataGrid ItemsSource="{Binding list}" [...]>
  [...]
</DataGrid>

我建议您使用ObservableCollection作为支持集合,因为它会将更改传播到数据网格,因为它会实现INotifyCollectionChanged

答案 2 :(得分:10)

实际上,要正确支持排序,过滤等,CollectionViewSource应该用作DataGrid和列表之间的链接,如下所示:

<Window.Resources>
  <CollectionViewSource x:Key="ItemCollectionViewSource" CollectionViewType="ListCollectionView"/>
</Window.Resources>   

DataGrid行如下所示:

<DataGrid
  DataContext="{StaticResource ItemCollectionViewSource}"
  ItemsSource="{Binding}"
  AutoGenerateColumns="False">  

在后面的代码中,您将CollectionViewSource与您的链接相关联。

CollectionViewSource itemCollectionViewSource;
itemCollectionViewSource = (CollectionViewSource)(FindResource("ItemCollectionViewSource"));
itemCollectionViewSource.Source = itemList;

有关详细示例,请参阅我在CoedProject上的文章: http://www.codeproject.com/Articles/683429/Guide-to-WPF-DataGrid-formatting-using-bindings

答案 3 :(得分:3)

您不需要在xaml中手动提供列名。只需将AutoGenerateColumns属性设置为true,您的列表将自动绑定到DataGrid。参考代码。 XAML代码:

<Grid>
    <DataGrid x:Name="MyDatagrid" AutoGenerateColumns="True" Height="447" HorizontalAlignment="Left" Margin="20,85,0,0" VerticalAlignment="Top" Width="799"  ItemsSource="{Binding Path=ListTest, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"  CanUserAddRows="False"> </Grid>

C#

Public Class Test 
{
    public string m_field1_Test{get;set;}
    public string m_field2_Test { get; set; }
    public Test()
    {
        m_field1_Test = "field1";
        m_field2_Test = "field2";
    }
    public MainWindow()
    {

        listTest = new List<Test>();

        for (int i = 0; i < 10; i++)
        {
            obj = new Test();
            listTest.Add(obj);

        }

        this.MyDatagrid.ItemsSource = ListTest;

        InitializeComponent();

    }