当放置在WPF中的网格内时,无法在datagrid中看到垂直滚动条

当放置在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

从最后两天开始,我陷入了一个小问题,我不知道为什么我不能解决它。为了解决这个问题,我做了很多工作,并实现了堆栈溢出提供的各种建议,但最终由于实现不成功而感到厌倦

我的问题是,我想要一个可滚动的数据网格,它可以放在网格控件或DockPanel中(正如我尝试过的那样)。下面是我正在使用的代码

<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
a
StackPanel
的父节点之一吗?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">