繁体   English   中英

WPF DataTrigger 为假,但不会恢复到以前的值

[英]WPF DataTrigger is false but doesn't revert to previous value

我最近创建了一个用户控件,通知用户他有多少通知。 因为我希望这个用户控件只在有任何通知时才显示自己,所以我创建了一个绑定到布尔值的 DataTrigger,并在没有通知时将可见性设置为折叠。 它在开始时工作正常,我的用户控件已折叠,但在我的程序中,我添加了一个通知并在我的 bool 上调用 NotifyPropertyChanged 但用户控件仍因某种未知原因保持隐藏状态。

用户控制

<UserControl.Style>
    <Style TargetType="{x:Type UserControl}">
        <Setter Property="Visibility"
                    Value="Visible">
        </Setter>
        <Style.Triggers>
            <DataTrigger Binding="{Binding HasNotifications}"
                             Value="False">
                <Setter Property="Visibility"
                            Value="Collapsed">
                </Setter>
            </DataTrigger>
        </Style.Triggers>
    </Style>
</UserControl.Style>

数据上下文

private ObservableCollection<Notification> notifications;
public ObservableCollection<Notification> Notifications
{
    get { return notifications; }
}

public bool HasNotifications
{
    get
    {
        return Notifications.Count > 0;
    }
}

public void AddNotification(Notification notificationToAdd)
{
    notifications.Add(notificationToAdd);
    NotifyPropertyChanged(nameof(Notifications));
    NotifyPropertyChanged(nameof(HasNotifications));
}

public event PropertyChangedEventHandler PropertyChanged;

protected virtual void NotifyPropertyChanged(string propertyName)
{
    PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
}

我还尝试放置一个具有相反值的 DataTrigger(当 HasNotifications 为真时将可见性设置为 on),但它对我来说也不起作用。

我复制了您的代码并在 3.5 和 4.7 框架下对其进行了测试,并且可以正常工作。 我只能在一种情况下重现您的问题,但我在这里猜测,因为该部分不在您的代码示例中。

仅当数据上下文 class 不继承自INotifyPropertyChanged时,它才起作用。 否则,最小代码示例将按预期工作。

public class MyDataContext :  INotifyPropertyChanged // <= doesn't work if this is missing
{
    private ObservableCollection<Notification> notifications = new ObservableCollection<Notification>();
    public ObservableCollection<Notification> Notifications => notifications;

    public bool HasNotifications=> Notifications.Count > 0;

    public void AddNotification(Notification notificationToAdd)
    {
        notifications.Add(notificationToAdd);
        NotifyPropertyChanged(nameof(Notifications));
        NotifyPropertyChanged(nameof(HasNotifications));
    }

    private ICommand _AddNotification;
    public ICommand AddNotificationCMD => _AddNotification ?? (_AddNotification = new RelayCommand<object>(a => AddNotificationCommand(a)));

    private void AddNotificationCommand(object item)
    {
        AddNotification(new Notification());
    }

    public event PropertyChangedEventHandler PropertyChanged;
    protected virtual void NotifyPropertyChanged(string propertyName)
    {
        PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
    }
}

<Window x:Class="WpfApp_3_5_framework_test.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    xmlns:local="clr-namespace:WpfApp_3_5_framework_test"
    mc:Ignorable="d"
    Title="MainWindow" Height="450" Width="800">
<Grid>
    <local:UserControl1/>
    <Button Content="Add Notification" Command="{Binding AddNotificationCMD}" Height="20" Width="200" />
</Grid>
</Window>

public partial class MainWindow : Window
{
    public MainWindow()
    {
        InitializeComponent();
        this.DataContext = new MyDataContext();
    }
}

<UserControl x:Class="WpfApp_3_5_framework_test.UserControl1"
         xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
         xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
         xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
         xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
         xmlns:local="clr-namespace:WpfApp_3_5_framework_test"
         mc:Ignorable="d" 
         d:DesignHeight="450" d:DesignWidth="800">
<UserControl.Style>
    <Style TargetType="{x:Type UserControl}">
        <Setter Property="Visibility"
                Value="Visible">
        </Setter>
        <Style.Triggers>
            <DataTrigger Binding="{Binding HasNotifications}"
                         Value="False">
                <Setter Property="Visibility"
                        Value="Collapsed">
                </Setter>
            </DataTrigger>
        </Style.Triggers>
    </Style>
</UserControl.Style>
<Grid>
    <StackPanel>
        <Border Width="100" Height="100" Background="Red"/>
    </StackPanel>
</Grid>
</UserControl>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM