关于wpf网格行删除的奇怪结果

时间:2012-07-26 11:36:03

标签: wpf grid

我对网格删除有疑问:

每当我删除网格中的最后一行或所有行时,网格上仍然会显示某些内容(实际上是最后一行)。我确实检查过grid.rowdefinitions.count是0.我使用的方法是removeAt和removeRange(0,grid.rowdefinitions.count)。那有什么不对?任何人都能说出原因吗?非常感谢!

//------------
<Grid DockPanel.Dock="Top" HorizontalAlignment="Left" Name="grid1" ShowGridLines="true" Width="200" Height="200">
                <Grid.ColumnDefinitions>
                    <ColumnDefinition/>
                    <ColumnDefinition/>
                </Grid.ColumnDefinitions>
                <Grid.RowDefinitions>
                    <RowDefinition/>
                    <RowDefinition/>
                    <RowDefinition/>
                    <RowDefinition/>
                    <RowDefinition/>
                </Grid.RowDefinitions>
                <TextBlock Grid.Row="0" Grid.Column="0" Text="100" />
                <TextBlock Grid.Row="1" Grid.Column="0" Text="200" />
                <TextBlock Grid.Row="2" Grid.Column="0" Text="300" />
                <TextBlock Grid.Row="3" Grid.Column="0" Text="400" />
                <TextBlock Grid.Row="4" Grid.Column="0" Text="500" />
            </Grid>
            <StackPanel HorizontalAlignment="Left" Orientation="Horizontal" Width="200" DockPanel.Dock="Top">
                <Button Width="80" Click="rem5Row">Remove 5 Rows</Button>
            </StackPanel>

//--------------

private void rem5Row(object sender, RoutedEventArgs e)
        {
            if (grid1.RowDefinitions.Count < 5)
            {
                Console.WriteLine("less than 5!");
            }
            else
            {
                grid1.RowDefinitions.RemoveRange(0,grid1.RowDefinitions.Count);
            }
        }

1 个答案:

答案 0 :(得分:1)

我不确定我是否正确理解了您的问题(而且我不确定代码是否反映了您所说的内容)。但是:你怎么知道“最后一行”正在显示?

我怀疑发生的事情是:您正在删除行并期望这些行中的控件也被删除。但是,这不是WPF Grid的功能:控件不是其行的子项,并且在删除RowDefinition时不会删除它们。

因此,所有子控件仍将呈现,但由于它们的Grid.Row无效,它们将呈现在“行0”位置。它们以标记顺序呈现,因此最终结果将显示为显示“最后一行”,因为这是最后绘制的控件。事实上,你的所有控件仍然存在;他们只是在屏幕上的同一个地方。

如果要确认这一点,可以使用Snoop检查运行时UI。或者,设置文本框的宽度,使行0框更宽 - 然后您将清楚地看到重叠。