WPF中DataGrid实现多选框功能

1. 效果图

2. Model建立

cs 复制代码
public class RstModelCheck : ObservableObject
{
    //为了显示Head1和Head2.而且View中绑定属性而非字段,否则不能显示。
    public string? Name { get; set; }    
    public bool PlatenAll 
    {
        get => _platenAll;
        set
        {
            SetProperty(ref _platenAll, value);
            PlatenA = value;
            PlatenB = value;
            PlatenC = value;
            PlatenD = value;
        }
    }
    public bool PlatenA 
    {
        get => _platenA;
        set => SetProperty(ref _platenA, value);
    }
    public bool PlatenB
    {
        get => _platenB;
        set => SetProperty(ref _platenB, value);
    }
    public bool PlatenC
    {
        get => _platenC;
        set => SetProperty(ref _platenC, value);
    }
    public bool PlatenD
    {
        get => _platenD;
        set => SetProperty(ref _platenD, value);
    }

    private bool _platenAll;
    private bool _platenA;
    private bool _platenB;
    private bool _platenC;
    private bool _platenD;

    public RstModelCheck(string name)
    {
        this.Name = name;
    }
}

3. ViewModel编写

cs 复制代码
public ObservableCollection<RstModelCheck> IsCheckRstModel
{
    get => _isCheckRstModel;
    set => SetProperty(ref _isCheckRstModel, value);
}
private ObservableCollection<RstModelCheck> _isCheckRstModel = new();

//构造函数中添加:
IsCheckRstModel.Add(new RstModelCheck("Head1"));
IsCheckRstModel.Add(new RstModelCheck("Head2"));

4. View中Xaml编写

cs 复制代码
<DataGrid ItemsSource="{Binding IsCheckRstModel}" AutoGenerateColumns="False" SelectionUnit="Cell" ColumnHeaderHeight="20">
    <DataGrid.Columns>
        <DataGridTextColumn Header="Platen" Binding="{Binding Name}" IsReadOnly="True" CanUserSort="False" Selector.IsSelected="False"/>
        <DataGridCheckBoxColumn Header="AllSet" Binding="{Binding Path=PlatenAll,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}" CanUserSort="False"/>
        <DataGridCheckBoxColumn Header="A" Binding="{Binding PlatenA}" CanUserSort="False"/>
        <DataGridCheckBoxColumn Header="B" Binding="{Binding PlatenB}" CanUserSort="False"/>
        <DataGridCheckBoxColumn Header="C" Binding="{Binding PlatenC}" CanUserSort="False"/>
        <DataGridCheckBoxColumn Header="D" Binding="{Binding PlatenD}" CanUserSort="False"/>
    </DataGrid.Columns>
</DataGrid>
相关推荐
大菜菜2 分钟前
Molecule Framework -EditorService API 详细文档
前端
Anita_Sun3 分钟前
😋 核心原理篇:线程池的 5 大核心组件
前端·node.js
运维@小兵5 分钟前
Spring-AI系列——Tool Calling获取当前时间
java·后端·spring
认真敲代码的小火龙7 分钟前
【JAVA项目】基于JAVA的养老院管理系统
java·开发语言·课程设计
灼华_7 分钟前
Web前端移动端开发常见问题及解决方案(完整版)
前端
he___H8 分钟前
滑动窗口一题
java·数据结构·算法·滑动窗口
_请输入用户名8 分钟前
Vue3 Patch 全过程
前端·vue.js
孟祥_成都9 分钟前
nest.js / hono.js 一起学!字节团队如何配置多环境攻略!
前端·node.js
扶苏-su9 分钟前
Java---事件处理机制
java·开发语言
用户40993225021210 分钟前
Vue3数组语法如何高效处理动态类名的复杂组合与条件判断?
前端·ai编程·trae