単純なオブジェクトリストを使用できます。それから、DataGridを作成し、DataRecordListをそれにバインドします。 フロントエンドは、次のようになります。
<Window x:Class="TestDataGrid.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:Data="clr-namespace:TestDataGrid"
Title="MainWindow" Height="350" Width="525">
<Window.Resources>
<ResourceDictionary>
<Data:DataRecordList x:Key="DataSource"/>
<CollectionViewSource x:Key="DataCollection" Source="{StaticResource DataSource}"/>
</ResourceDictionary>
</Window.Resources>
<Grid>
<DataGrid Name="GridData"
ItemsSource="{Binding Source={StaticResource DataCollection}}"
AutoGenerateColumns="False"
CanUserDeleteRows="True" CanUserAddRows="True">
<DataGrid.Columns>
<DataGridTextColumn Header="ID" Binding="{Binding Path=ID}"/>
<DataGridTextColumn Header="Name" Binding="{Binding Path=Name}"/>
<DataGridTextColumn Header="SomeValue" Binding="{Binding Path=SomeValue}"/>
</DataGrid.Columns>
</DataGrid>
</Grid>
</Window>
と、このような背後にあるコード:
namespace TestDataGrid
{
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
}
}
public class DataRecord
{
public int ID { get; set; }
public string Name { get; set; }
public string SomeValue { get; set; }
}
public class DataRecordList : List<DataRecord>
{
public DataRecordList()
{
this.Add(new DataRecord() { ID = 1, Name = "Johnny", SomeValue = "Dummy" });
this.Add(new DataRecord() { ID = 2, Name = "Grace", SomeValue = "Foo" });
this.Add(new DataRecord() { ID = 3, Name = "Steve", SomeValue = "Bar" });
}
}
}
あなたは、行を追加する行を削除し、偶数行だけでなく、ソートを編集して、列の順序を変更することができます。 お楽しみください。 JiKra