Silverlight 利用DataGrid行加载事件动态控制行列显示

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 % 5 == 0)
                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[0].GetCellContent(e.Row).FindName("tb") as TextBox; //定位同比这一列
            if (bindData.zbbm == "xjl")
               btn.IsReadOnly = true;
        }

顺便说一下,行加载很好用,但具体控制表格的每一行或某行某列的某个子控件时,就需要我们做好定位工作,就需要平时积累控件定位的功夫啦!

比如:

TextBlock aa = dg_source2.Columns[0].GetCellContent(e.Row) as TextBlock;  //定位到具体单元格(标准列),这里注意要将具体cell转换为TextBlock方便操作

效果图如下:

先总结到这,学习并积累哈。

 

posted @ 2016-01-26 11:25  Prolovecui  阅读(1114)  评论(0编辑  收藏  举报