gpt4 book ai didi

c# - ReactiveUI - 为什么简单的 ReactiveList.Changed -> ToProperty 不起作用?

转载 作者:太空狗 更新时间:2023-10-30 00:30:22 26 4
gpt4 key购买 nike

我尝试了许多不同的修改,但没有任何帮助。当我深入研究资源时,它是一堆涉及静态状态的深层魔法,如 ConditionalWeakTable 等。

private readonly ReactiveList<Item> _list = new ReactiveList<Item>();

private decimal _sum;
public decimal Sum
{
get { return _sum; }
set { this.RaiseAndSetIfChanged(ref _sum, value); }
}

_list
.Changed
.Select(_ => _list.Select(i => i.Value).Sum())
.ToProperty(this, x => x.Sum)

最佳答案

你的方法(在问题中)的问题是你没有使用 .ToProperty() 调用的返回值,这是 ObservableAsPropertyHelper 类。返回值将被忽略。

RxUI 在围绕属性编写代码时实际上很简单。它们只是一个样板,您永远不应该对其进行重大修改。在您的情况下,您想使用一个输出属性 模式,描述为here in the docs。 .适应您的示例,您不需要带有 RaiseAndSetIfChanged 的 setter 。相反,你应该使用这样的东西:

private readonly ReactiveList<Item> _list = new ReactiveList<Item>();

private readonly ObservableAsPropertyHelper<decimal> _sum;
public decimal Sum {
get { return _sum.Value; }
}

// in constructor
_sum = _list
.Changed
.Select(_ => _list.Select(i => i.Value).Sum())
.ToProperty(this, x => x.Sum);

正如您已经注意到的,ToProperty 有一个重载,它接受对 ViewModel 中的 ObservableAsPropertyHelper 字段的输出引用,您可以使用它(就像在您的答案中一样)。最后,您选择的过载是风格/品味的问题。下面的代码与上面的代码完全相同:

// in constructor, alternatively
_list
.Changed
.Select(_ => _list.Select(i => i.Value).Sum())
.ToProperty(this, x => x.Sum, out _sum);

关于c# - ReactiveUI - 为什么简单的 ReactiveList.Changed -> ToProperty 不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37812237/

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