回答
使用Snoop来分析一个测试程序,我放在一起的视觉树后,我想出了使用DataGrid_Loaded事件该解决方案):
private void TheGrid_Loaded(object sender, RoutedEventArgs e) {
var dataGrid = (DataGrid)sender;
var border = (Border)VisualTreeHelper.GetChild(dataGrid, 0);
var scrollViewer = (ScrollViewer)VisualTreeHelper.GetChild(border, 0);
var grid = (Grid)VisualTreeHelper.GetChild(scrollViewer, 0);
var button = (Button)VisualTreeHelper.GetChild(grid, 0);
button.IsEnabled = false;
}
可能有一个更优雅的XAML唯一的解决方案,但这是首先想到的,它似乎工作得很好(我显然没有做任何异常处理)。
注意:我还没有玩过禁用/重新启用DataGrid以确保全选按钮停留停用。如果它不保持禁用状态,那么您可能还想挂钩DataGrid_IsEnabledChanged事件。
希望这有助于!
这是一个糟糕的解决方案,很容易在xaml构造中修改。如果您只想禁用按钮,请按照Eben的建议使用绑定命令,或者如果您想隐藏按钮,则按Varun的建议禁用显示。 – TheRoadrunner 2014-10-28 08:50:23
在DataGrid
有一个属性HeadersVisibility
。它有四个值 - All
,Column
,,None
。
随着HeadersVisibility = All
,你会得到SelectAll按钮。
与HeadersVisibility = Column
,你将只获得列。不是SelectAll按钮或行标题来选择一个完整的行。
随着HeadersVisibility = Row
,你将只获得行头选择整行。不是SelectAll按钮或列。
与HeadersVisibility = None
,你什么也得不到。所有标题将被隐藏。
我希望这可以帮助你。
将命令绑定添加到SelectAll命令并在CanExecute中返回false以禁用selectall按钮。
我会改变Control Templat
ËDataGrid中的。 需要在模板内禁用此按钮。 这是DataGrid
ControlTemplate
:
<ControlTemplate TargetType="{x:Type DataGrid}">
<Border BorderBrush="{TemplateBinding BorderBrush}"
BorderThickness="{TemplateBinding BorderThickness}"
Background="{TemplateBinding Background}"
Padding="{TemplateBinding Padding}"
SnapsToDevicePixels="True">
<ScrollViewer x:Name="DG_ScrollViewer"
Focusable="false">
<ScrollViewer.Template>
<ControlTemplate TargetType="{x:Type ScrollViewer}">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="*" />
<ColumnDefinition Width="Auto" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="Auto" />
<RowDefinition Height="*" />
<RowDefinition Height="Auto" />
</Grid.RowDefinitions>
<Button Command="{x:Static DataGrid.SelectAllCommand}"
Focusable="false"
Style="{DynamicResource {ComponentResourceKey ResourceId=DataGridSelectAllButtonStyle, TypeInTargetAssembly={x:Type DataGrid}}}"
Visibility="{Binding HeadersVisibility, ConverterParameter={x:Static DataGridHeadersVisibility.All}, Converter={x:Static DataGrid.HeadersVisibilityConverter}, RelativeSource={RelativeSource AncestorType={x:Type DataGrid}}}"
Width="{Binding CellsPanelHorizontalOffset, RelativeSource={RelativeSource AncestorType={x:Type DataGrid}}}" />
<DataGridColumnHeadersPresenter x:Name="PART_ColumnHeadersPresenter"
Grid.Column="1"
Visibility="{Binding HeadersVisibility, ConverterParameter={x:Static DataGridHeadersVisibility.Column}, Converter={x:Static DataGrid.HeadersVisibilityConverter}, RelativeSource={RelativeSource AncestorType={x:Type DataGrid}}}" />
<ScrollContentPresenter x:Name="PART_ScrollContentPresenter"
CanContentScroll="{TemplateBinding CanContentScroll}"
Grid.ColumnSpan="2"
Grid.Row="1" />
<ScrollBar x:Name="PART_VerticalScrollBar"
Grid.Column="2"
Maximum="{TemplateBinding ScrollableHeight}"
Orientation="Vertical"
Grid.Row="1"
Visibility="{TemplateBinding ComputedVerticalScrollBarVisibility}"
Value="{Binding VerticalOffset, Mode=OneWay, RelativeSource={RelativeSource TemplatedParent}}"
ViewportSize="{TemplateBinding ViewportHeight}" />
<Grid Grid.Column="1"
Grid.Row="2">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="{Binding NonFrozenColumnsViewportHorizontalOffset, RelativeSource={RelativeSource AncestorType={x:Type DataGrid}}}" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<ScrollBar x:Name="PART_HorizontalScrollBar"
Grid.Column="1"
Maximum="{TemplateBinding ScrollableWidth}"
Orientation="Horizontal"
Visibility="{TemplateBinding ComputedHorizontalScrollBarVisibility}"
Value="{Binding HorizontalOffset, Mode=OneWay, RelativeSource={RelativeSource TemplatedParent}}"
ViewportSize="{TemplateBinding ViewportWidth}" />
</Grid>
</Grid>
</ControlTemplate>
</ScrollViewer.Template>
<ItemsPresenter SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" />
</ScrollViewer>
</Border>
</ControlTemplate>
它手动禁用按钮,并指定这个ControlTemplate
您DataGrid
。
- 1. DataGrid/ListBox中的WPF按钮
- 2. WPF:将按钮列添加到Datagrid
- 3. WPF Datagrid ColumHeader MouseOver关闭按钮
- 4. WPF Datagrid浏览按钮问题
- 5. 选择单选按钮,wpf
- 6. 按钮上的Datagrid行选择单击WPF
- 7. WPF中的DataGridTemplateColumn中的浏览按钮Datagrid中的按钮
- 8. ASPxListBox“全选”按钮
- 9. WPF DataGrid筛选器
- 10. WPF DataGrid全行编辑
- 11. Datagrid中的按钮
- 12. 为什么我的Windows 8 WPF单选按钮全部出错?
- 13. 创建“全选”按钮来选择所有按钮
- 14. WPF DataGridHeaderTemplate作为按钮
- 15. WPF Datagrid无法选择行
- 16. WPF DataGrid行选择问题
- 17. WPF Datagrid风格选择行
- 18. wpf datagrid复选框列
- 19. 复选框DataGrid中MVVM WPF
- 20. WPF datagrid多行选择
- 21. 如何使添加的按钮对Wpf Datagrid中的选定行可见
- 22. 入门按钮选定的报告文件行从WPF的Datagrid点击
- 23. 如何在扩展器的右角添加按钮 - WPF DataGrid
- 24. WPF DataGrid - 添加项目,如果按钮被点击
- 25. Click事件WPF DataGrid的按钮列添加在PowerShell中
- 26. 如何将wpf datagrid scrollviewer visiblity绑定到按钮可见性?
- 27. WPF Datagrid双向绑定:点击按钮添加行
- 28. 使用删除按钮删除WPF Datagrid中的行
- 29. 如何在wpf中的datagrid中动态添加按钮?
- 30. 通过单击删除键按钮来删除DataGrid行(WPF)
我不确定禁用它,但我发现隐藏你的RowHeaders会隐藏它。 (对我造成问题是因为我想隐藏RowHeaders但显示SelectAll按钮) – Rachel 2010-11-19 16:35:16