Avalonia DataGrid 多选需设 SelectionMode="Extended" 并用 Behavior 绑定 SelectedItems;SelectedItem 仅表焦点行,SelectedItems 才存全部选中项;注意 NuGet 包、主题、集合类型及通知机制。
Avalonia DataGrid 默认不支持直接绑定多选集合,SelectionMode 仅控制选择行为模式(如单选、扩展多选),但不会自动同步选中项到 ViewModel。要实现真正可用的多选功能,需配合行为(Behavior)或手动监听事件完成双向同步。
这是启用多选操作的前提。Extended 允许按 Ctrl/Shift 多选,Multiple 在 Avalonia 当前版本中效果等同于 Extended(官方文档与实际行为一致):
SelectionMode="Extended"
CanUserSelectRows="True"(默认为 true,但显式声明更稳
妥)SelectionMode="Single" 或未设置时,将无法进行多选操作官方 DataGrid 不提供 SelectedItems 的依赖属性绑定,需借助自定义 Behavior 实现 MVVM 同步:
DataGridSelectedItemsBehavior 类,监听 SelectionChanged 事件IList SelectedItems { get; set; } 属性(推荐用 ObservableCollection 或 INotifyCollectionChanged 实现) 引入并绑定:
SelectedItem 是单值绑定,仅反映当前“焦点行”;SelectedItems 才是真正被勾选的全部项集合(类型为 IList):
SelectedItem 判断多选结果var selected = SelectedItems.Cast().ToList();
ObservableCollection,建议在 ViewModel 中维护一个独立的 ObservableCollection 用于存储选中项,避免直接操作 SelectedItems 引发类型不匹配多选功能容易因配置疏漏失效:
Avalonia.Xaml.Behaviors NuGet 包 → Behavior 无法解析App.axaml 中引入 Fluent.xaml 或 DataGrid 主题 → 控件样式异常,部分交互不可见ItemsSource 使用普通 List 而非 ObservableCollection → 数据更新后 UI 不响应,影响选择状态渲染[Reactive](若使用 ReactiveUI)或未实现 INotifyPropertyChanged → SelectedItems 变化无法通知 UI