如果字段中没有数据,如何在UWP中折叠数据绑定控件

时间:2016-08-09 02:54:36

标签: listview hide uwp bind no-data

我正在开发一个在ListView中绑定数据的UWP应用程序。我一直试图找到一种在没有数据时折叠(隐藏)控件的方法。例如,我制作了一个我正在做的简单版本:

<ListView Name="lvwMaster" ItemsSource="{x:Bind CollectionOfPeople}">
    <ListView.ItemTemplate>
        <DataTemplate x:DataType="data:Person">
            <StackPanel Name="pnlOnePerson" Margin="10">
                <TextBlock Name="lblFirstName" Text="{x:Bind FirstName}" />
                <TextBlock Name="lblMiddleName" Text="{x:Bind MiddleName}" Height="Auto" />
                <TextBlock Name="lblLastName" Text="{x:Bind LastName}" />
                <TextBlock Name="lblBirthDate" Text="{x:Bind BirthDate}" />
            </StackPanel>
        </DataTemplate>
    </ListView.ItemTemplate>
</ListView>

由于不是每个人都有中间名,我希望中间名字段在空时隐藏。

example of what it looks like when run

当这个人没有中间名时,我可以隐藏中间名字段的任何建议吗?

1 个答案:

答案 0 :(得分:1)

使用数值转换器

class TextToVisibilityConverter : IValueConverter
{
    public object Convert(object value, Type targetType, object parameter, string language)
    {
        string name = System.Convert.ToString(value);
        if (string.IsNullOrEmpty(name))
        {
            return Visibility.Collapsed;
        }
        return Visibility.Visible;        }

    public object ConvertBack(object value, Type targetType, object parameter, string language)
    {
        throw new NotImplementedException();
    }
}

将Converter定义为页面内的静态资源。

<Page.Resources> 
  <local:TextToVisibilityConverter x:Name="ConverterNameHere"/> 
</Page.Resources>
数据模板中的

就像这样使用它,

<DataTemplate x:DataType="data:Person">
                    <StackPanel Name="pnlOnePerson" Margin="10">
                        <TextBlock Name="lblFirstName" Text="{x:Bind FirstName}" />
                        <TextBlock Name="lblMiddleName" Text="{x:Bind MiddleName}" Height="Auto" Visibility ="{Binding path=Text, ElementName="lblMiddleName" Converter={StaticResource ConverterNameHere}}" />
                        <TextBlock Name="lblLastName" Text="{x:Bind LastName}" />
                        <TextBlock Name="lblBirthDate" Text="{x:Bind BirthDate}" />
                    </StackPanel>
                </DataTemplate>