我喜欢 ReactiveUI 的基于代码的绑定(bind)机制。但是,有时您需要使用 XAML 绑定(bind)。在这些情况下,需要在 View 和 ViewModel 之间正确设置 DataContext。我一直在 View 构造函数中这样做:
public MyView()
{
InitializeComponent();
this.WhenActivated(disposables =>
{
this.DataContext = this.ViewModel;
...
});
}
这可行,但我在运行时的输出窗口中出现错误:
System.Windows.Data Error: 40 : BindingExpression path error: ...
我正在使用 ReactiveUserControls、ViewModelViewHosts,并在 Locator 中注册 View/ViewModel 映射并让 ReactiveUI 解决它们。我想我会尽早设置 DataContext 。因此,当我需要使用 XAML 绑定(bind)时 - 是否有另一种设置 DataContext 以避免幻像调试输出错误的方法?
最佳答案
您所拥有的问题是您永远不会自适应地获得 ViewModel 的新版本,并且您可能会延迟订阅。
您最好考虑使用 WhenAnyValue() 运算符,例如:
this.WhenAnyValue(x => x.ViewModel).Bindto(this, x => x.DataContext);
考虑仍然在您的 WhenActivated() 中播放它,因为这将避免内存泄漏,否则保留对 IDisposable 的引用并在您的 View 关闭时进行处置。
关于reactiveui - 使用 ReactiveUI 进行 Xaml 绑定(bind)时避免绑定(bind)错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51827412/