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>
相关推荐
_Mya_1 天前
后端接口又改了?让 Apifox MCP 帮你自动同步类型定义
前端·人工智能·mcp
_AaronWong1 天前
一键搞定UniApp WiFi连接!这个Vue 3 Hook让你少走弯路
前端·微信小程序·uni-app
摸着石头过河的石头1 天前
JavaScript继承与原型链:揭开对象传承的神秘面纱
前端·javascript
_大学牲1 天前
Flutter 之魂 GetX🔥(二)全面解析路由管理
前端·flutter
星链引擎1 天前
客服机器人面向初学者的通俗版
前端
LRH1 天前
React 双缓存架构与 diff 算法优化
前端·react.js
golang学习记1 天前
Next.js 16 来了:引领全栈开发新潮流
前端
不爱编程的小九九1 天前
小九源码-springboot082-java旅游攻略平台
java·开发语言·旅游
只是懒得想了1 天前
用C++实现一个高效可扩展的行为树(Behavior Tree)框架
java·开发语言·c++·design-patterns