我正在搜索如何以MvvM方式从ToolKit动态创建DataGrid的列。但看起来这是不可能的!
是否有人必须做同样的事情?
不需要创建来自DataGrid的usercontrol或其他控件,我只想将网格的de ItemSource设置为我的自定义对象,并且在某些时候我想在运行时基于动态定义网格的列在那种对象中。
这可能吗?
欢呼声
答案 0 :(得分:9)
我要说明这可能不是最好的解决方案,可能在某些情况下不起作用,但你可以尝试一下,看看它是否适用于你想要的东西。我只是鞭打了它,所以它可能有一些错误。它仍然会涉及一些代码,但它会让你的模型不知道你的观点。
您需要做的是创建一个扩展属性,该属性允许您绑定DataGrid上的Columns属性。这是我放在一起的一个例子。
using System.Collections.ObjectModel;
using System.Collections.Specialized;
using System.Windows;
using System.Windows.Controls;
public static class DataGridExtension
{
public static ObservableCollection<DataGridColumn> GetColumns(DependencyObject obj)
{
return (ObservableCollection<DataGridColumn>)obj.GetValue(ColumnsProperty);
}
public static void SetColumns(DependencyObject obj, ObservableCollection<DataGridColumn> value)
{
obj.SetValue(ColumnsProperty, value);
}
public static readonly DependencyProperty ColumnsProperty =
DependencyProperty.RegisterAttached("Columns",
typeof(ObservableCollection<DataGridColumn>),
typeof(DataGridExtension),
new UIPropertyMetadata (new ObservableCollection<DataGridColumn>(),
OnDataGridColumnsPropertyChanged));
private static void OnDataGridColumnsPropertyChanged(
DependencyObject d,
DependencyPropertyChangedEventArgs e)
{
if (d.GetType() == typeof(DataGrid))
{
DataGrid myGrid = d as DataGrid;
ObservableCollection<DataGridColumn> Columns =
(ObservableCollection<DataGridColumn>)e.NewValue;
if(Columns != null)
{
myGrid.Columns.Clear();
if (Columns != null && Columns.Count > 0)
{
foreach (DataGridColumn dataGridColumn in Columns)
{
myGrid.Columns.Add(dataGridColumn);
}
}
Columns.CollectionChanged += delegate(object sender,
NotifyCollectionChangedEventArgs args)
{
if(args.NewItems != null)
{
foreach (DataGridColumn column
in args.NewItems.Cast<DataGridColumn>())
{
myGrid.Columns.Add(column);
}
}
if(args.OldItems != null)
{
foreach (DataGridColumn column
in args.OldItems.Cast<DataGridColumn>())
{
myGrid.Columns.Remove(column);
}
}
};
}
}
}
}
然后将它附加到DataGrid,就像这样(其中columns是视图模型上的ObservableCollection属性)
<Controls:DataGrid AutoGenerateColumns="False"
DataGridExtension.Columns="{Binding Columns}" />
如果您开始添加和删除列,我不确定它会如何响应,但它似乎可以从我的基本测试开始。祝你好运!
答案 1 :(得分:1)
遇到类似的问题,我不想添加另一个依赖属性。 我的解决方法是组织数据以在DataTable中的DataGrid中显示,并将DataGrid ItemSource属性绑定到此DataTable(当然AutoGenerateColumns设置为true)。
效果很好,DataGrids似乎对DataTable作为源代码感到满意。
答案 2 :(得分:0)
我想扩展前面的示例(回答)订阅和取消订阅事件CollectionChanged的能力。 Link on my answer in related theme