我将代码中的行添加到我在Xaml中定义的DataGrid。
DataTable dt = new DataTable();
DataRow dr1 = dt.NewRow();
DataRow dr2 = dt.NewRow();
DataRow dr3 = dt.NewRow();
dr1.Style = (Style)Resources.FindName("CustomStyle");
dataGrid.ItemSource = dt;
dr1没有名为Style的属性所以我怎么能这样做?
这应该很简单,但我很难过。
我知道在XAML中这很简单,但需要在代码后面完成,因为我无法定义XAML中的行数,因为它们会被动态添加。
答案 0 :(得分:0)
您可以使用DataTrigger
执行此操作。在下面的示例中,如果State
的值为State1
,则该值为红色,如果为State2
,则为Green
。您可以将它绑定到数据表的另一个属性,另一个值以及您喜欢的任何颜色。
<DataGrid ItemsSource="{Binding YourItemsSource}">
<DataGrid.RowStyle>
<Style TargetType="DataGridRow">
<Style.Triggers>
<DataTrigger Binding="{Binding State}" Value="State1">
<Setter Property="Background" Value="Red"></Setter>
</DataTrigger>
<DataTrigger Binding="{Binding State}" Value="State2">
<Setter Property="Background" Value="Green"></Setter>
</DataTrigger>
</Style.Triggers>
</Style>
</DataGrid.RowStyle>
</DataGrid>
答案 1 :(得分:0)
可以在Xaml中完成,如CodingYoshi所述。
如果您需要完整的代码隐藏解决方案,那么您可以参考这个。
public MainWindow()
{
InitializeComponent();
DataTable dt = new DataTable();
dt.Columns.Add("Col", typeof(string));
DataRow dr1 = dt.NewRow();
dr1[0] = "row1" ;
DataRow dr2 = dt.NewRow();
dr2[0] = "row2";
DataRow dr3 = dt.NewRow();
dr3[0] = "row3";
dt.Rows.Add(dr1);
dt.Rows.Add(dr2);
dt.Rows.Add(dr3);
dataGrid.ItemsSource = dt.AsDataView();
dataGrid.ItemContainerGenerator.StatusChanged += ItemContainerGenerator_StatusChanged;
}
private void ItemContainerGenerator_StatusChanged(object sender, EventArgs e)
{
// This will ensure, items are generated over UI.
if (dataGrid.ItemContainerGenerator.Status == GeneratorStatus.ContainersGenerated)
{
int index = 1; // add logic to get index of row to be styled.
var row = (DataGridRow)dataGrid.ItemContainerGenerator
.ContainerFromIndex(index);
// creating style, can be picked from resources aswell.
Style style = new Style
{
TargetType = typeof(Control)
};
style.Setters.Add(new Setter(Control.BackgroundProperty, Brushes.Green));
// Applied logic
row.Style = style;
}
}