[英]Change wpf data grid row background color when checkbox is checked
当给定行的复选框被选中时,我试图更改数据网格行的颜色,而当未选中该复选框时,应将值重置为前一个值。
我正在使用MVVM来实现上述功能。
我的XAML代码:-
<Window.Resources>
<Style x:Key="RowStyle" TargetType="{x:Type DataGridRow}">
<Style.Triggers>
<DataTrigger Binding="{Binding DataContext.IsChecked, UpdateSourceTrigger=PropertyChanged}" Value="True">
<Setter Property="Background" Value="Red"/>
</DataTrigger>
</Style.Triggers>
</Style>
</Window.Resources>
<Grid>
<DataGrid Name="lbUsers" ItemsSource="{Binding Data}" CanUserAddRows="False" Grid.Column="1" Grid.Row="1" SelectedIndex="{Binding SelectionIndexChange, Mode=TwoWay}" AutoGenerateColumns="False">
<DataGrid.Columns>
<DataGridTemplateColumn>
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<CheckBox Width="45" Height="20" Command="{Binding ElementName=lbUsers,Path=DataContext.IsChecked}" ></CheckBox>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
</DataGrid.Columns>
</DataGrid>
</Grid>
下面给出的是视图模型代码:
public ViewModel ()
{
Data = new ObservableCollection<CommonData>
{
};
}
private ObservableCollection<CommonData> _data;
public ObservableCollection<CommonData> Data
{
get
{
if (_data == null)
{
_data = new ObservableCollection<CommonData>()
{
};
}
return _data;
}
set
{
if (value != this._data)
{
this._data = value;
NotifyPropertyChanged("Data");
}
}
}
private bool _isChecked;
public bool IsChecked
{
get { return _isChecked; }
set { this._isChecked = value; NotifyPropertyChanged("IsChecked"); }
}
请让我知道我在做错什么才能使给定的功能正常工作。
在此先感谢您,如果缺少信息,请告诉我。
几件事:
您已经为样式分配了x:Key
,但是没有在DataGrid
上使用它。 删除键以使其成为所有DataGridRow
的默认样式,或将其添加到网格中:
RowStyle="{StaticResource RowStyle}"
在DataTrigger
绑定中,您还需要添加
ElementName=lbUsers
此外,您的Checkbox
未正确绑定-不能通过Command
完成。 您将需要改变
Command={Binding...
至
IsChecked={Binding...
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.