最近在项目中很多的地方都用到了数据的展示---DataGrid控件,在园子里面也有很多的朋友也对这个DataGrid控件也写了很多的教程;我这里也与其它人也没有什么区别,这里只是告诉大家一个小的技巧;但是我相信这一个小的技巧对大家以后在项目中应该有一些帮助;一天,领导走过来看了我用户管理UI,我用了一个DataGrid控件把用户用分页的方式给做了出来;这个用户里面有用户的部门,用户名,地址,等相关信息;领导看了,说你的用户信息可以有一种层次结构就最好了,这一听他这句话,我就回答说,这个可以做的,我说可以按照部门来分组的;这里我就加上了一两句代码,按照领导的要求满足了,也有了层次结构;可是领导看了,还是不很满意;他说,你看怎么给用户看英文,一定要把英文改成中文,并且这分组的这一行要与其它的行要有突出显示出来这时,我没有直接的回答领导的问题,我说,这个让我看看,能解决;为了解决领导的这个问题,我花费了很多的时间,在网上也没有看到这种的解决方案;最后没有办法,认真的去看Silverlight 帮助了;呵呵,通过去查帮助,找到了一解决方案;
public class Student
{
public string Name { get; set; }
public int Age { get; set; }
public string Phone { get; set; }
}
把得到的数据,分组显示出来:
public void BindDataGrid()
{
PagedCollectionView pcv = new PagedCollectionView(getData);
pcv.GroupDescriptions.Add(new System.Windows.Data.PropertyGroupDescription("Name"));
MyDataGrid.ItemsSource = pcv;
}
运行效果如下所示:
这时我们怎么来给上面图上的英文“Name”变成用户知道的意思呢?
void MyDataGrid_LoadingRowGroup(object sender, DataGridRowGroupHeaderEventArgs e)
{
e.RowGroupHeader.PropertyName = "姓名";
}
运行结果如下所示:
上面图中我们就达到领导的要求了,把英文修改成让用户能看懂的意思了;接下来满足领导的第二个要求;只要给分组的行着色就可以与数据行区别开来了;
ottom:10px; margin-left:5px; padding-top:10px; padding-right:10px; padding-bottom:10px; padding-left:10px; font-family:Verdana, DataGridRowGroupHeaderEventArgs e)
{
e.RowGroupHeader.PropertyName = "姓名";
e.RowGroupHeader.Background = new SolidColorBrush(Colors.Orange);
}
运行结果如下所示:
总结:就这两个小问题,如果是第一次碰到,一定会让你痛苦一段时间,没有办法用户就是上帝,结果这两个问题都让我解决了;在项目中我也碰到了很多的技术上的问题,目前碰到的问题差不多,都慢慢的得到了解决;在以后,我会把我在项目中的技术性的问题与大家一起分享;
出处:http://www.cnblogs.com/caodaiming