在我的WPF应用程序中,我有Student和StudentDB类。
class StudentDB
{
int StudentId{get;set;}
string Name{get;set;}
string City{get;set;}
DateTimeOffset BirthDate{get;set;}
}
class Student
{
int StudentId{get;set;}
string Name{get;set;}
string City{get;set;}
DateTime BirthDate{get;set;}
}
两个类之间的主要区别是Birthday属性的数据类型。一个是DateTime
,另一个是DateTimeOffset
。
我的申请表中有以下代码。
IEnumerable<StudentDB> StudentDbs = GetAllStudentFromDB();
IEnumerable<Student> Students = new IEnumerable<Student> Students();
XAML:
<DataGrid ItemsSource="{Binding Students, Mode=TwoWay}" AutoGenerateColumns="True">
我需要在DataGrid中显示学生列表。
我无法绑定StudentDbs,因为它具有DateTimeOffset
类型属性。
要解决上述问题,我需要应用Value Converter
,这会将StudentDb
对象转换为Student
对象。
我知道如何实现IValueConverter接口I.但我不知道如何将它应用于集合。
有人能建议我解决这个问题吗?
答案 0 :(得分:1)
回答主要要求:DateTimeOffset类有一个名为 DateTime 的属性,它表示当前System.DateTimeOffset对象的日期和时间。因此,您仍然可以将StudentDbs绑定为DataGrid的Itemsource,并且可以在DataGrid中的任何位置直接绑定 BirthDate.DateTime 属性以满足您的要求。
答案 1 :(得分:0)
您不需要值转换器。
更好的方法是通过LINQ将StudentDB
转换为Student
,或者在ViewModel中以其他方式转换,然后将Student
个对象的集合绑定到DataGrid
。
IEnumerable<StudentDB> StudentDbs = GetAllStudentFromDB();
IEnumerable<Student> Students = new StudentDbs.Select(student => ConvertToDto(student));
private Student ConvertToDto(StudentDB)
{
return new Student
{
StudentId = StudentId,
Name = Name,
City = City,
BirthDate = BirthDate.DateTime
};
}
<DataGrid ItemsSource="{Binding Students, Mode=TwoWay}" AutoGenerateColumns="True">
最好使用ObservableCollection<T>
来防止内存泄漏并允许更改集合。
答案 2 :(得分:0)
值转换器应用于列。所以设置AutoGenerateColumns =&#34; False&#34;并手动添加列:
<DataGrid.Columns>
<DataGridTextColumn Header="{lex:Loc ...}"
Binding="{Binding StarString, Converter={StaticResource ...}}">
当AutoGenerating为true时,使用DataGrid的AutoGeneratingColumn事件。在xaml中添加:
<DataGrid ItemsSource="{Binding Students, Mode=TwoWay}" AutoGenerateColumns="True" AutoGeneratingColumn="StartListGrid_OnAutoGeneratingColumn"
在后面的代码中添加如下内容:
private void StartListGrid_OnAutoGeneratingColumn(object sender, DataGridAutoGeneratingColumnEventArgs e)
{
if (e.PropertyName == "BirthDate" && e.Column is DataGridTextColumn)
{
var textColumn = e.Column as DataGridTextColumn;
textColumn.Binding = new Binding(e.PropertyName)
{
Converter = new MyValueConverter();
};
}
}
请注意,您正在覆盖Binding。