Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/mongodb/12.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
在WPF数据网格中动态生成列?_Wpf_Datagrid - Fatal编程技术网

在WPF数据网格中动态生成列?

在WPF数据网格中动态生成列?,wpf,datagrid,Wpf,Datagrid,在上面的代码片段中,DataGrid列是在XAML中硬编码的 是否可以在其他地方定义列定义,最好是在MVVM视图模型中,以便可以动态定义和重新定义列?当然可以 我没有考虑超过5秒,但以下是如何做到这一点: 1.定义数据网格的附加属性,当该属性设置为true时,您将注册到网格加载的事件,当事件激发时,您将从发送方参数提取其上下文,然后将他发送给一个方法,该方法将用列填充他。使用MicrosoftDataGrid和MVVM模式,以下方式对我有效,因为DataGrid会根据DataTable自动生成列

在上面的代码片段中,DataGrid列是在XAML中硬编码的


是否可以在其他地方定义列定义,最好是在MVVM视图模型中,以便可以动态定义和重新定义列?

当然可以

我没有考虑超过5秒,但以下是如何做到这一点:
1.定义数据网格的附加属性,当该属性设置为true时,您将注册到网格加载的事件,当事件激发时,您将从发送方参数提取其上下文,然后将他发送给一个方法,该方法将用列填充他。

使用Microsoft
DataGrid
和MVVM模式,以下方式对我有效,因为
DataGrid
会根据
DataTable
自动生成列

在XAML中,我包括
DataGrid

<DataGrid ItemsSource="{Binding}" AutoGenerateColumns="False">
  <DataGrid.Columns>
    <DataGridTextColumn Header="First Name" Binding="{Binding FirstName}" />
  </DataGrid.Columns>
</DataGrid>

您可以通过在ItemsSource集合中实现接口来实现它

将使用从方法返回的s自动生成s,而无需通过内部使用方法生成任何额外的XAML

<WpfToolkit:DataGrid 
    ItemsSource="{Binding Path=GridData, Mode=OneWay}" > 
</WpfToolkit:DataGrid> 
public DataView GridData 
{ 
  get 
  { 
    DataSet ds = new DataSet("MyDataSet"); 

    // everything hard-coded for this example 
    int to = 12;
    int ps = 2048;
    string sv = "10";
    string st = "Open";
    string wsid = "ZAMBONI";

    DataTable dt = new DataTable("MyDataTable");
    DataColumn propertyName = new DataColumn("Property");
    DataColumn propertyValue = new DataColumn("Value");
    dt.Columns.Add(propertyName);
    dt.Columns.Add(propertyValue);
    dt.Rows.Add("Connection timeout", to);
    dt.Rows.Add("Packet size", ps);
    dt.Rows.Add("Server version", sv);
    dt.Rows.Add("State", st);
    dt.Rows.Add("Worksation id", wsid);
    ds.Tables.Add(dt);

    return ds.Tables[0].DefaultView; 
  } 
}