如何在WPF中向datagrid / datatable添加行

时间:2014-12-18 21:02:33

标签: c# wpf mvvm datagrid datatable

我想要做的是使用Datagrid在运行时隐藏和显示列。

我正在使用MVVM,我有一个带有ItemsSource的DataGrid,如下所示:

 ItemsSource="{Binding ComponentsPropertiesGrid}" 
 views:DataGridColumnsBehavior.BindableColumns="{Binding dataGridColumn}"

其中DataGridColumnsBehavior是以下类。

public class DataGridColumnsBehavior
{
    public static readonly DependencyProperty BindableColumnsProperty =
        DependencyProperty.RegisterAttached("BindableColumns",
                                            typeof(ObservableCollection<DataGridColumn>),
                                            typeof(DataGridColumnsBehavior),
                                            new UIPropertyMetadata(null, BindableColumnsPropertyChanged));
    private static void BindableColumnsPropertyChanged(DependencyObject source, DependencyPropertyChangedEventArgs e)
    {
        DataGrid dataGrid = source as DataGrid;
        ObservableCollection<DataGridColumn> columns = e.NewValue as ObservableCollection<DataGridColumn>;
        dataGrid.Columns.Clear();
        if (columns == null) { return; }

        foreach (DataGridColumn column in columns)
        {
            dataGrid.Columns.Add(column);
        }

        columns.CollectionChanged += (sender, e2) =>
        {
            NotifyCollectionChangedEventArgs ne = e2 as NotifyCollectionChangedEventArgs;
            if (ne.Action == NotifyCollectionChangedAction.Reset)
            {
                dataGrid.Columns.Clear();
                if (ne.NewItems != null)
                {
                    foreach (DataGridColumn column in ne.NewItems)
                    {
                        dataGrid.Columns.Add(column);
                    }
                }
            }
            else if (ne.Action == NotifyCollectionChangedAction.Add)
            {
                if (ne.NewItems != null)
                {
                    foreach (DataGridColumn column in ne.NewItems)
                    {
                        dataGrid.Columns.Add(column);
                    }
                }
            }
            else if (ne.Action == NotifyCollectionChangedAction.Move)
            {
                dataGrid.Columns.Move(ne.OldStartingIndex, ne.NewStartingIndex);
            }
            else if (ne.Action == NotifyCollectionChangedAction.Remove)
            {
                if (ne.OldItems != null)
                {
                    foreach (DataGridColumn column in ne.OldItems)
                    {
                        dataGrid.Columns.Remove(column);
                    }
                }
            }
            else if (ne.Action == NotifyCollectionChangedAction.Replace)
            {
                dataGrid.Columns[ne.NewStartingIndex] = ne.NewItems[0] as DataGridColumn;
            }
        };
    }
    public static void SetBindableColumns(DependencyObject element, ObservableCollection<DataGridColumn> value)
    {
        element.SetValue(BindableColumnsProperty, value);
    }
    public static ObservableCollection<DataGridColumn> GetBindableColumns(DependencyObject element)
    {
        return (ObservableCollection<DataGridColumn>)element.GetValue(BindableColumnsProperty);
    }
}

此时,我可以在运行时添加和删除列,只有当我的数据表没有列时才添加/删除它们到dataGridColumn集合。如果我的数据表中没有列,我该如何添加行?

 DataRow newRow = ComponentsPropertiesGrid.NewRow();

 newRow[componentName] = "Test";

当我尝试时,它会抛出异常,因为componentName不是dataTable中的有效列。

如果还有其他方法,我们可以试试。

0 个答案:

没有答案