ListView填充父,屏幕或任何[重复]的宽度

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ListView填充父,屏幕或任何[重复]的宽度相关的知识,希望对你有一定的参考价值。

这个问题在这里已有答案:

我试图从Observable Collection显示一些数据到ListView。绑定工作正常。我无法解决的唯一问题是ListView的布局。我使用一个包含2行的Grid来分割我的View。 ListView是第二行之一。我只尝试使用*来设置大多数来源中建议的列和行。 ListView的代码就是这个。

<Grid Grid.Row="1" Margin="10,0,10,0" HorizontalAlignment="Stretch">
    <ListView ItemsSource="{Binding Collection}" HorizontalAlignment="Stretch">
        <ListView.ItemTemplate>
            <DataTemplate>
                <Grid HorizontalAlignment="Stretch">
                    <Grid.ColumnDefinitions>
                        <ColumnDefinition Width="*"/>
                        <ColumnDefinition Width="*"/>
                        <ColumnDefinition Width="*"/>
                    </Grid.ColumnDefinitions>
                    <TextBlock Grid.Column="0" HorizontalAlignment="Center" Text="{Binding Period}" Foreground="{StaticResource ColorBrush}" FontFamily="{StaticResource Family}" FontSize="20"/>
                    <TextBlock Grid.Column="1" HorizontalAlignment="Center" Text="{Binding Currency}" Foreground="{StaticResource ColorBrush}" FontFamily="{StaticResource Family}" FontSize="20"/>
                    <TextBlock Grid.Column="2" HorizontalAlignment="Center" Text="{Binding Date}" Foreground="{StaticResource ColorBrush}" FontSize="20" FontFamily="{StaticResource Family}"/>
                </Grid>
            </DataTemplate>
        </ListView.ItemTemplate>
    </ListView>
</Grid>

当我对包含ListView和ListView本身的网格使用Horizo​​ntalAlignment =“Stretch”时,数据显示在左侧而不获取父视图的整个宽度。当我明确地将Width设置为某​​个值(即380)时,它显示OK。

<Grid Grid.Row="1" Margin="10,0,10,0">
    <ListView ItemsSource="{Binding Collection}" Width="380">
        <ListView.ItemTemplate>
            <DataTemplate>
                <Grid Width="380">
                    <Grid.ColumnDefinitions>
                        <ColumnDefinition Width="*"/>
                        <ColumnDefinition Width="*"/>
                        <ColumnDefinition Width="*"/>
                    </Grid.ColumnDefinitions>
                    <TextBlock Grid.Column="0" HorizontalAlignment="Center" Text="{Binding Period}" Foreground="{StaticResource ColorBrush}" FontFamily="{StaticResource Family}" FontSize="20"/>
                    <TextBlock Grid.Column="1" HorizontalAlignment="Center" Text="{Binding ValueInCurrency}" Foreground="{StaticResource ColorBrush}" FontFamily="{StaticResource Family}" FontSize="20"/>
                    <TextBlock Grid.Column="2" HorizontalAlignment="Center" Text="{Binding Date}" Foreground="{StaticResource ColorBrush}" FontSize="20" FontFamily="{StaticResource Family}"/>
                </Grid>
            </DataTemplate>
        </ListView.ItemTemplate>
    </ListView>
</Grid>

但我想知道一种不使用隐式值的更好方法,但*。

答案

试试这个。在</ListView.ItemTemplate>之后添加以下jus

<ListView.ItemContainerStyle>
    <Style TargetType="ListViewItem">
        <Setter Property="HorizontalContentAlignment" Value="Stretch"/>
    </Style>
</ListView.ItemContainerStyle>

以上是关于ListView填充父,屏幕或任何[重复]的宽度的主要内容,如果未能解决你的问题,请参考以下文章

在 React Native 中,两个等宽的按钮水平填充屏幕

在LaunchScreen处ImageView的宽度填充父级宽度时保存图像比例(高度)

100% 宽度减去边距和填充 [重复]

Bootstrap - 当屏幕尺寸较小时删除填充或边距

Div 内的 Div 填充整个父 DIV 而不显示:表格 [重复]

宽度=“*”的网格列未按预期使用所有可用空间[重复]