110,561
社区成员
发帖
与我相关
我的任务
分享
请问你这个后面实现出来了吗?
<Window x:Class="BDM.UserGui.Test.TestDataGrid"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:BDM.UserGui.Test"
xmlns:core="clr-namespace:System;assembly=mscorlib"
xmlns:util="clr-namespace:BDM.UserGui.Utils"
mc:Ignorable="d"
Title="测试" Height="250" Width="800" Loaded="Window_Loaded">
<Window.Resources>
<ObjectDataProvider x:Key="sexEnum" MethodName="GetValues" ObjectType="{x:Type core:Enum}">
<ObjectDataProvider.MethodParameters>
<x:Type Type="local:Sex1" />
</ObjectDataProvider.MethodParameters>
</ObjectDataProvider>
<util:EnumBoolConverter x:Key="enumBoolConverter" />
</Window.Resources>
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition />
<RowDefinition />
</Grid.RowDefinitions>
<DataGrid Name="dgWorkStep" AutoGenerateColumns="False" Grid.Row="0" Grid.Column="0">
<DataGrid.Columns>
<DataGridTextColumn Width="60" Header="编号" Binding="{Binding Id}" IsReadOnly="True" />
<DataGridTextColumn Width="90" Header="姓名" Binding="{Binding Name}" />
<DataGridComboBoxColumn Width="120" Header="性别" SelectedItemBinding="{Binding Sex}" ItemsSource="{Binding Source={StaticResource sexEnum}}">
</DataGridComboBoxColumn>
</DataGrid.Columns>
</DataGrid>
<Grid Grid.Row="1" Grid.Column="0" Name="grid1">
<Grid.ColumnDefinitions>
<ColumnDefinition />
<ColumnDefinition />
<ColumnDefinition />
<ColumnDefinition />
<ColumnDefinition />
<ColumnDefinition />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition />
<RowDefinition />
<RowDefinition />
</Grid.RowDefinitions>
<Label HorizontalContentAlignment="Right" VerticalContentAlignment="Center" Grid.Row="0" Grid.Column="0">姓名</Label>
<TextBox Name="txtName" HorizontalContentAlignment="Left" VerticalContentAlignment="Center" Grid.Row="0" Grid.Column="1" Margin="3" Text="{Binding Path=Name, Mode=TwoWay}" />
<Label HorizontalContentAlignment="Right" VerticalContentAlignment="Center" Grid.Row="0" Grid.Column="2">地址</Label>
<TextBox Name="txtAddress" HorizontalContentAlignment="Left" VerticalContentAlignment="Center" Grid.Row="0" Grid.Column="3" Margin="3" Text="{Binding Path=Address, Mode=TwoWay}" />
<Label HorizontalContentAlignment="Right" VerticalContentAlignment="Center" Grid.Row="0" Grid.Column="4">性别</Label>
<StackPanel Orientation="Horizontal" Grid.Row="0" Grid.Column="5">
<RadioButton Name="rbtnSexMale" HorizontalContentAlignment="Left" VerticalContentAlignment="Center" Margin="4" IsChecked="{Binding Sex, Converter={StaticResource enumBoolConverter},ConverterParameter=1}">男</RadioButton>
<RadioButton Name="rbtnSexFemale" HorizontalContentAlignment="Left" VerticalContentAlignment="Center" Margin="4" IsChecked="{Binding Sex, Converter={StaticResource enumBoolConverter},ConverterParameter=2}">女</RadioButton>
</StackPanel>
<Button Name="btnReplace" Content="更换" Grid.Column="0" Grid.Row="1" Margin="5" Click="btnReplace_Click" />
<Button Name="btnView" Content="查看" Grid.Column="1" Grid.Row="1" Margin="5" Click="btnView_Click" />
<Button Name="btnAdd" Content="添加" Grid.Column="2" Grid.Row="1" Margin="5" Click="btnAdd_Click" />
</Grid>
</Grid>
</Window>
窗体类文件
/// <summary>
/// TestDataGrid.xaml 的交互逻辑
/// </summary>
public partial class TestDataGrid : Window {
private List<Student> studentList = null;
public TestDataGrid() {
InitializeComponent();
}
private void Window_Loaded(object sender, RoutedEventArgs e) {
List<Student> list = new List<Student>();
for (int i = 0; i < 4; i++) {
Student p = new Student();
p.Name = "学生 " + i;
p.Sex = (i % 2 == 0) ? Sex1.男生 : Sex1.女生;
list.Add(p);
}
this.studentList = list;
this.dgWorkStep.ItemsSource = list;
Student student = new Student();
student.Id = 1000L;
student.Name = "原始姓名";
student.Address = "原住民";
student.Sex = Sex1.女生;
this.grid1.DataContext = student;
}
private void btnReplace_Click(object sender, RoutedEventArgs e) {
Student stu = new Student();
stu.Id = 10000L;
stu.Name = "张三";
stu.Address = "广东省东莞市";
stu.Sex = Sex1.男生;
this.grid1.DataContext = stu;
}
private void btnView_Click(object sender, RoutedEventArgs e) {
Student stu = this.grid1.DataContext as Student;
Console.WriteLine(stu.Id);
Console.WriteLine(stu.Name);
Console.WriteLine(stu.Address);
}
private void btnAdd_Click(object sender, RoutedEventArgs e) {
Student student = new Student();
student.Id = 1000L;
student.Name = "新加的名字";
student.Address = "新地址";
student.Sex = Sex1.女生;
this.studentList.Add(student);
}
}
Student 类
public class Student : INotifyPropertyChanged {
private long? _id;
private string _name;
private string _address;
private Sex1 _sex;
private void Notify(string propName) {
if (PropertyChanged == null)
return;
PropertyChanged(this, new PropertyChangedEventArgs(propName));
}
public long? Id {
get {
return _id;
}
set {
_id = value;
this.Notify("Id");
}
}
public string Name {
get {
return _name;
}
set {
_name = value;
this.Notify("Name");
}
}
public string Address {
get {
return _address;
}
set {
_address = value;
this.Notify("Address");
}
}
public Sex1 Sex {
get {
return _sex;
}
set {
_sex = value;
this.Notify("Sex");
}
}
public event PropertyChangedEventHandler PropertyChanged;
}
private void DataGrid_InitializingNewItem(object sender, InitializingNewItemEventArgs e)
{
if (StuList == null || StuList.Count == 0)
{
((Student)e.NewItem).Id = 1;
}
else
{
((Student)e.NewItem).Id = StuList.Max(p => p.Id) + 1;
}
((Student)e.NewItem).Selected = true;
}