datagrid的绑定很好用,但有时候我们往往需要根据model内容来动态控制行或者列,该怎么办呢?
这时候,我们就需要用到行加载事件:在加载每一行数据的时候,根据数据的内容来控制相应的表格显示。
比如我们想要每五行置行底色为红色,可以这样:
SolidColorBrush r = new SolidColorBrush(Colors.Red);
private void dataGrid1_LoadingRow(object sender, DataGridRowEventArgs e)
{
CData c = e.Row.DataContext as CData;
if (c.id % == )
e.Row.Background = r;
else
e.Row.Background = new SolidColorBrush(Colors.White); }
如果,你想根据model的值,改变某一行某一自定义列的样式或内容,你也可以这样:
private void dg_source2_LoadingRow(object sender, DataGridRowEventArgs e)
{
db_lsyjbInfo bindData = (db_lsyjbInfo)e.Row.DataContext;
TextBox btn = dg_source2.Columns[].GetCellContent(e.Row).FindName("tb") as TextBox; //定位同比这一列
if (bindData.zbbm == "xjl")
btn.IsReadOnly = true;
}
顺便说一下,行加载很好用,但具体控制表格的每一行或某行某列的某个子控件时,就需要我们做好定位工作,就需要平时积累控件定位的功夫啦!
比如:
TextBlock aa = dg_source2.Columns[].GetCellContent(e.Row) as TextBlock; //定位到具体单元格(标准列),这里注意要将具体cell转换为TextBlock方便操作
效果图如下:
先总结到这,学习并积累哈。