Caliburn.Micro,MVVM 模式:CanExecute 命令不起作用



这是我的观点:

<StackPanel Orientation="Horizontal" VerticalAlignment="Top">
    <Label>Customer name:</Label>
    <TextBox Text="{Binding Customer.Name, UpdateSourceTrigger=PropertyChanged}" Width="136"/>
    <Button x:Name="UpdateClick">Update</Button>
</StackPanel>

这是我的ViewModel:

private Customer customer;
public Customer Customer
{
    get { return customer; }
    set { customer = value; NotifyOfPropertyChange(() => Customer); }
}
public bool CanUpdateClick 
{ 
    get 
    {
        if (string.IsNullOrEmpty(customer.Name))
        {
            return false;
        }
        return true; 
    } 
}
public void UpdateClick()
{
    //...
}

这是我的模型:

private string name;
public string Name
{
    get { return name; }
    set { name = value; NotifyOfPropertyChange(() => Name); }
}

所以我有UpdateClick方法,它可以很好地工作。我也有CanupdateClick属性,但它不起作用,我不知道为什么?当文本框为空时,应禁用UI上的按钮。请帮忙!

您可以订阅Customer类的PropertyChanged事件(因为您似乎是子分类PropertyChangedBase)并在更改Name属性时致电NotifyOfPropertyChanged(() => CanUpdateClick)

// in your view model
// i'm assuming here that Customer is set before your view model is activated
protected override void OnActivate()
{
    base.OnActivate();
    Customer.PropertyChanged += CustomerPropertyChangedHandler;
}
protected override void OnDeactivate(bool close)
{
    base.OnDeactivate(close);
    // unregister handler
    Customer.PropertyChanged -= CustomerPropertyChangedHandler;
}
// event handler
protected void CustomerPropertyChangedHandler(object sender, PropertyChangedEventArgs e)
{
    if (e.PropertyName == nameof(Customer.Name))
    {
        NotifyOfPropertyChange(() => CanUpdateClick);
    }
}

或者,您可以在视图模型中创建NameCustomerName属性以绑定到a))使用Customer.Name作为备份字段或b)使用普通备份字段,然后在更新时设置Customer.Name

在您的视图中:

<TextBox Text="{Binding CustomerName, UpdateSourceTrigger=PropertyChanged}" Width="136"/>

这是您在视图模型中实现选项A的方式:

public string CustomerName
{
    get { return Customer.Name; }
    set
    {
        Customer.Name = value;
        NotifyOfPropertyChange(); // CallerMemberName goodness
        NotifyOfPropertyChange(() => CanUpdateClick);
    }
}

最新更新