我有一个非常基本的WPF应用程序,它附带一个MS SQL服务器作为数据源。我的datagrid声明如下:
<DataGrid HorizontalAlignment="Left" Margin="10,88,0,0" VerticalAlignment="Top" Height="456" Width="1018" ItemsSource="{Binding}" />
当我运行应用程序时,我看到数据从数据库加载到网格中,但列标题看起来很奇怪。最初包含下划线的每个标题都删除了此下划线:some_title
转为sometitle
。
我发现这是因为下划线被识别为控制符号,可以将下一个符号转换为助记符。
如何禁用此行为?
我发现,如果您将单个下划线加倍,即some__title
而不是some_title
,则可以绕过此行为。但由于我的数据源是外部数据库,所以我不能影响它。或者可能使用转换器?
我认为最好的方法是将属性RecognizesAccessKey
转换为false
,但遗憾的是它无法以某种方式访问。
我是WPF的新手,谢谢你的帮助!
P.S。她是Snoop的照片(如果有帮助的话)
编辑我的目标框架是.net 4.5
答案 0 :(得分:5)
即使这是一个老问题,我也解决了这个问题。这可能对某人有帮助。
9223372036854775808
答案 1 :(得分:3)
我能想出的最佳解决方案是拦截DataGrid事件AutoGeneratingColumn
并用两个下划线替换所有下划线,如下所示:
private void DataGrid_AutoGeneratingColumn_1(object sender, DataGridAutoGeneratingColumnEventArgs e)
{
string header = e.Column.Header.ToString();
// Replace all underscores with two underscores, to prevent AccessKey handling
e.Column.Header = header.Replace("_", "__");
}
根据我的理解,(遗憾的是)如果不重新定义整个控件模板,则无法覆盖基础RecognizesAccessKey
的{{1}}的值。
在msdn论坛上查看此主题:How to set RecognizesAccessKey on labels without influencing other parameters?。
答案 2 :(得分:1)
您可以使用自定义列,当您使用自定义列时,您可以根据需要定义列标题。
答案 3 :(得分:0)
要添加到接受的答案,如果要保持datagrid的原始样式,请执行以下操作,并将ContentPresenter的RecognizeAccessKey更改为False。
<Style TargetType="{x:Type DataGridColumnHeader}">
<Setter Property="VerticalContentAlignment" Value="Center"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type DataGridColumnHeader}">
<Grid>
<Themes:DataGridHeaderBorder BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" IsClickable="{TemplateBinding CanUserSort}" IsPressed="{TemplateBinding IsPressed}" IsHovered="{TemplateBinding IsMouseOver}" Padding="{TemplateBinding Padding}" SortDirection="{TemplateBinding SortDirection}" SeparatorBrush="{TemplateBinding SeparatorBrush}" SeparatorVisibility="{TemplateBinding SeparatorVisibility}">
<ContentPresenter ContentTemplate="{TemplateBinding ContentTemplate}" Content="{TemplateBinding Content}" ContentStringFormat="{TemplateBinding ContentStringFormat}" HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" RecognizesAccessKey="False" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}"/>
</Themes:DataGridHeaderBorder>
<Thumb x:Name="PART_LeftHeaderGripper" HorizontalAlignment="Left">
<Thumb.Style>
<Style TargetType="{x:Type Thumb}">
<Setter Property="Width" Value="8"/>
<Setter Property="Background" Value="Transparent"/>
<Setter Property="Cursor" Value="SizeWE"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type Thumb}">
<Border Background="{TemplateBinding Background}" Padding="{TemplateBinding Padding}"/>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</Thumb.Style>
</Thumb>
<Thumb x:Name="PART_RightHeaderGripper" HorizontalAlignment="Right">
<Thumb.Style>
<Style TargetType="{x:Type Thumb}">
<Setter Property="Width" Value="8"/>
<Setter Property="Background" Value="Transparent"/>
<Setter Property="Cursor" Value="SizeWE"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type Thumb}">
<Border Background="{TemplateBinding Background}" Padding="{TemplateBinding Padding}"/>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</Thumb.Style>
</Thumb>
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>