gpt4 book ai didi

wpf - 数据绑定(bind)如何避免 WPF 中的递归更新?

转载 作者:行者123 更新时间:2023-12-04 16:13:13 24 4
gpt4 key购买 nike

我正在研究 WPF 中的绑定(bind),然后我有这个问题:

假设依赖属性绑定(bind)到实现 INotifyPropertyChanged 接口(interface)的对象的属性。

当绑定(bind)目标更新源时,源的属性也会更新。

由于源对象的属性 setter 发生了变化,它会反过来通知监听器——绑定(bind)目标,这将导致递归更新。

在 WPF 中如何避免这种情况?

最佳答案

由属性更改事件引起的对源的更新不会触发绑定(bind),并且在绑定(bind)更新源时发生的属性更改事件将被忽略。

这是一个简单的方法来证明这一点。创建这个类:

public class TestClass : INotifyPropertyChanged
{
public event PropertyChangedEventHandler PropertyChanged;

private int _Property;

public int Property
{
get { return _Property; }
set
{
if (value < 1000) // just to be on the safe side
{
_Property = value + 1;
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs("Property"));
}
}
}
}
}

现在创建一个包含两个 TextBox 的窗口其 Text绑定(bind)到 Property此类实例上的属性。使两者都使用双向绑定(bind), UpdateSourceTrigger设置为 PropertyChanged .

每当您在任一绑定(bind) TextBox 中键入一个数字时, 其他 TextBox将显示下一个数字。第一个 TextBox 上的绑定(bind)正在忽略 PropertyChanged源引发的事件,因为该事件在绑定(bind)期间发生。第二个文本框确实由第一个 PropertyChanged 更新。事件,但它不会使用其新值更新源。

如果您在代码中更新属性(例如在按钮单击事件中), TextBox es 将显示相同的值 - 例如如果将属性设置为 20,则两者都将显示 21。当属性设置为 20 时会触发 property-changed 事件,显示当前值 21,并且绑定(bind)不会更新源。

关于wpf - 数据绑定(bind)如何避免 WPF 中的递归更新?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2875096/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com