我有用于编辑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=true
和IsReadOnly=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);
}
当工作 - 我的班级。 工作完美。