如何将行添加到数据网格



我有用于编辑XML文件的小程序。我使用 XMLDataProvider:

<Grid.DataContext>
    <XmlDataProvider x:Name="XMLData" Source="/database/stroyka1.bas" XPath="JobArray/job"/>
</Grid.DataContext>

和数据网格:

<DataGrid 
    Name="JobsDataGrid" 
    ItemsSource="{Binding}"
    AutoGenerateColumns="false" Height="Auto" Width="Auto"
    IsReadOnly="False" CanUserAddRows="True">
    <DataGrid.Columns>
        <DataGridTextColumn Header="ID" Binding="{Binding XPath=id, Mode=TwoWay}" />
        <DataGridTextColumn Header="Название" Binding="{Binding XPath=name, Mode=TwoWay}" />
        <DataGridTextColumn Header="Цена за единицу" Binding="{Binding XPath=price, Mode=TwoWay}"/>
        <DataGridTextColumn Header="Единица измерения" Binding="{Binding XPath=measure, Mode=TwoWay}"/>
    </DataGrid.Columns>
</DataGrid>

如何在表格下方启用空白行? CanUserAddRow=trueIsReadOnly=false不起作用。我尝试将带有空白参数的行添加到 DataGrid,但出现错误:

使用项目源时不允许操作。相反,请使用 ItemsControl.ItemsSource 访问和修改元素。

这是解释。ItemsSource 集合必须实现一些接口才能正常工作。

非常感谢,但我找到了方法,但我对这个问题很敏感。我使用此代码:

private void AddNewRowMenuItem_OnClick(object sender, RoutedEventArgs e)
    {
        job pipainput = new job(JobsDataGrid.Items.Count+1,"",0,"");
        XmlSerializer xmls = new XmlSerializer(typeof(job));
        var sb = new StringBuilder(512);
        using (System.IO.StringWriter sw = new System.IO.StringWriter(sb))
            {
                xmls.Serialize(sw, pipainput);
            }
        XmlDocument xmlk = new XmlDocument();
        xmlk.LoadXml(sb.ToString());
        XmlNode pipa = XMLData.Document.ImportNode(xmlk.ChildNodes[1], true);
        XMLData.Document.DocumentElement.AppendChild(pipa);
    }    

当工作 - 我的班级。 工作完美。

相关内容

  • 没有找到相关文章

最新更新