WPf DataGrid设置按钮的显示与隐藏
在DataGrid表格中设置按钮,获取按钮的Name值,根据数据状态来显示按钮的隐藏和显示,由于是多个按钮,所以在DataGridTemplateColumn中设置了StackPane(应该也可以是其他的布局),不然的话会报出已多次设置属性的错误。
在后台获取绑定表格的数据,循环表格数据
再获取DataGridTemplateColumn所在列,是所需要的状态列,因为此处是根据个人所需列来判断的
DataGridTemplateColumn tempColumn = this.dgOrder.Columns[9] as DataGridTemplateColumn;
然后获取DataGridTemplateColumn单元格元素
FrameworkElement element = this.dgOrder.Columns[9].GetCellContent(this.dgOrder.Items[i]);
把单元格元素转换为相应的控件,再从该控件中取值
Button button = tempColumn.CellTemplate.FindName("btnDed", element) as Button;
Button button2 = tempColumn.CellTemplate.FindName("btn_palete", element) as Button;
Button button3 = tempColumn.CellTemplate.FindName("btn_Ady", element) as Button;
表格加载出来的时候获取不到索引,它会报出值为null的错误,然后去查了获取索引的方法,在表格加载出来时就选择到索引,然后调用了这个方法
public static DataGridRow GetDataGridRow(DataGrid datagrid, int rowIndex)
{
DataGridRow row = (DataGridRow)datagrid.ItemContainerGenerator.ContainerFromIndex(rowIndex);
if (row== null)
{
datagrid.UpdateLayout();
row = (DataGridRow)datagrid.ItemContainerGenerator.ContainerFromIndex(rowIndex);
row.IsSelected = true;
}
return row;
}
原图(样式请忽略)
显示效果
就是根据“已支付”和“未支付”来显示按钮的需要的