当放置在WPF中的网格内时,无法在datagrid中看到垂直滚动条
从最后两天开始,我陷入了一个小问题,我不知道为什么我不能解决它。为了解决这个问题,我做了很多工作,并实现了堆栈溢出提供的各种建议,但最终由于实现不成功而感到厌倦 我的问题是,我想要一个可滚动的数据网格,它可以放在网格控件或DockPanel中(正如我尝试过的那样)。下面是我正在使用的代码当放置在WPF中的网格内时,无法在datagrid中看到垂直滚动条,wpf,xaml,c#-4.0,wpf-controls,wpfdatagrid,Wpf,Xaml,C# 4.0,Wpf Controls,Wpfdatagrid,从最后两天开始,我陷入了一个小问题,我不知道为什么我不能解决它。为了解决这个问题,我做了很多工作,并实现了堆栈溢出提供的各种建议,但最终由于实现不成功而感到厌倦 我的问题是,我想要一个可滚动的数据网格,它可以放在网格控件或DockPanel中(正如我尝试过的那样)。下面是我正在使用的代码 <Grid IsEnabled="{Binding IsCalcVarGridPartEnable}"> <Grid.Resources> <Boolean
<Grid IsEnabled="{Binding IsCalcVarGridPartEnable}">
<Grid.Resources>
<BooleanToVisibilityConverter x:Key="boolToVisiblityConverter" />
<sys.converters:BoolToVisibleHiddenConvertor x:Key="boolToVisibleHiddenConvertor"/>
<FrameworkElement x:Key="ProxyElement"
DataContext="{Binding}"/>
</Grid.Resources>
<Grid.RowDefinitions>
<RowDefinition Height="30" />
<RowDefinition Height="*" />
<RowDefinition Height="30"/>
</Grid.RowDefinitions>
<Border Style="{StaticResource SeperatorStyle}" Grid.Row="0">
<TextBlock Style="{StaticResource BannerTextStyle}" Text="Calculation Variable" />
</Border>
<Border Style="{StaticResource SeperatorStyle}" Grid.Row="2">
<Button Content="Edit" HorizontalAlignment="Right" Margin="10,5" Command="{Binding EditCalcVarCmd}" />
</Border>
<ContentControl Visibility="Collapsed"
Content="{StaticResource ProxyElement}"/>
<DataGrid AutoGenerateColumns="False"
Name="dataGridCalcVar"
VerticalAlignment="Top"
HorizontalAlignment="Left"
IsReadOnly="True"
SelectionMode="Single"
SelectionUnit="FullRow"
ItemsSource="{Binding CalcVarCollection}"
SelectedItem="{Binding SelectedCalcVar}"
HorizontalScrollBarVisibility="Auto"
VerticalScrollBarVisibility="Auto"
>
<i:Interaction.Triggers>
<i:EventTrigger EventName="MouseDoubleClick" >
<i:InvokeCommandAction Command="{Binding CalcVarDoubleClickedCmd}" />
</i:EventTrigger>
</i:Interaction.Triggers>
<DataGrid.ColumnHeaderStyle>
<StaticResourceExtension ResourceKey="DataGridColumnHeaderStyle" />
</DataGrid.ColumnHeaderStyle>
<DataGrid.CellStyle>
<StaticResourceExtension ResourceKey="DataGridCellStyle" />
</DataGrid.CellStyle>
<DataGrid.Columns>
<DataGridTextColumn Header="Type Description" MinWidth="150" MaxWidth="200" Binding="{Binding CalcTypName}" />
<DataGridTextColumn Header="Variable Description" MinWidth="150" MaxWidth="200" Binding="{Binding CalcVarName}" />
<DataGridTextColumn Header="Major Description" MinWidth="150" MaxWidth="200" Binding="{Binding MjAcctTypDesc}"
Visibility="{Binding DataContext.IsMjMiAcctTypVisible, Source={StaticResource ProxyElement},
Converter={StaticResource boolToVisibleHiddenConvertor}}" />
<DataGridTextColumn Header="Minor Description" MinWidth="150" MaxWidth="200" Binding="{Binding MiAcctTypDesc}"
Visibility="{Binding DataContext.IsMjMiAcctTypVisible, Source={StaticResource ProxyElement},
Converter={StaticResource boolToVisibleHiddenConvertor}}" />
<DataGridTextColumn Header="DNA Value" MinWidth="50" MaxWidth="200" Binding="{Binding CalcVarValueName}" />
<DataGridTextColumn Header="Critical Value" MinWidth="50" MaxWidth="200" Binding="{Binding CriticalValueName}" />
<DataGridTextColumn Header="Note" MinWidth="150" MaxWidth="200" Binding="{Binding Note}" />
</DataGrid.Columns>
</DataGrid>
<sysclient:PartStatusView Grid.RowSpan="5" Grid.ColumnSpan="7"
Style="{DynamicResource PartStatusViewDefaultStyle}" IsTabStop="False"/>
</Grid>
重要提示:只有在设置Datagrid控件的最大高度时,我才能获得滚动条,但我不想设置行或Datagrid控件的最大高度属性。我希望当我调整窗口大小或任何可用空间时,datagrid被设置到该空间中,当我们查询数据时,如果数据大于可用空间,则datagrid会带来垂直滚动条
请帮帮我
我希望我能解释我的问题。:-:-)
谢谢,据我所知,这里有两个属性可以帮助您 向数据网格添加
Grid.Row=“1”
从该容器上移除VerticalAlignment=“Top”
,这实际上阻止了它从容器上获取高度
乙二醇
我假设你想把网格放在中间的行中,占用剩余的空间。< /p>这个代码< >网格< /代码>放置/使用?有可能是
Grid
aStackPanel
的父节点之一吗?Grid的父节点是用户控件。而UserControl
的父节点是什么?进入可视化树,看看是否有类似于StackPanel
或Canvas
的控件,实际上我使用的是核心开发人员提供的框架控件。所以应该有面板或内容控件。此解决方案不起作用。Datagrid高度增加以显示所有数据,但scrollbar未显示。我测试了它是否按预期工作,所有我无法测试的是您拥有的任何样式和模板。您是否可以发布一个显示此问题的代码工作示例?
<DataGrid AutoGenerateColumns="False"
Name="dataGridCalcVar"
Grid.Row="1"
HorizontalAlignment="Left"
IsReadOnly="True"
SelectionMode="Single"
SelectionUnit="FullRow"
ItemsSource="{Binding CalcVarCollection}"
SelectedItem="{Binding SelectedCalcVar}"
HorizontalScrollBarVisibility="Auto"
VerticalScrollBarVisibility="Auto">