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>
相关推荐
超哥--21 分钟前
B站视频内容智能分析系统(九):React 前端与管理面板
前端·react.js·前端框架
devilnumber1 小时前
Java 递归算法 详解 + 核心要点 + 实战运用 + 避坑指南
java·开发语言·算法
asdfg12589633 小时前
JavaBean是什么?怎么理解?有什么用途?
java·开发语言
Cutecat_3 小时前
视频字幕处理工具横向:提取模式 vs 编辑模式,该如何选择
android·前端·ios·语音识别
qq_422152574 小时前
PDF 加水印工具怎么选?2026 年文档版权保护方案对比
前端·pdf·github
kyriewen4 小时前
手写 Promise.all、race、any:不到 30 行代码,解决并发异步的所有姿势
前端·javascript·面试
摇滚侠4 小时前
SpringMVC 入门到实战 文件上传 75-77
java·后端·spring·maven·intellij-idea
brucelee1865 小时前
OpenClaw 浏览器控制(Chrome MCP)完整教程
前端·chrome
GIS数据转换器5 小时前
城市排水生命线安全运行监测平台深度解析
java·运维·人工智能·python·安全·数据挖掘·无人机
ct9785 小时前
React 状态管理方案深度对比
开发语言·前端·react