gpt4 book ai didi

wpf - 是否有在 XAML 中应用 Binding.ValidationRules 的简洁方法

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

我正在研究 WPF/XAML 中某些数据输入表单的验证规则。通过将验证规则显式应用于字段绑定(bind),我已经能够获得我想要的用户体验:

<Binding 
Path="qtyoffset"
NotifyOnValidationError="True"
ValidatesOnDataErrors="True"
UpdateSourceTrigger="PropertyChanged"
>
<Binding.ValidationRules>
<utility:DecimalValidationRule precision="1" />
</Binding.ValidationRules>
</Binding>

使用上述方法,每次按键都会验证该字段。如果用户输入“X”,该字段立即被标记为无效,错误消息显示在适当的位置,“提交”按钮立即被禁用,等等。一切都很好。如果用户在小数点后输入两位数,输入两位小数等,也会发生同样的情况。

我唯一的问题是冗长。上面的绑定(bind)代码需要为每个字段提供,如果在一个字段上不完全正确,则该字段将不太正确。我宁愿只指定绑定(bind)路径,并自动添加其余部分。在每个绑定(bind)上设置 NotifyOnValidationError、ValidatesOnDataErrors 和 UpdateSourceTrigger,根据绑定(bind)的类型设置适用于特定数据类型的验证规则。或者,至少,根据我在 XAML 中指定的类型。

我正在考虑在 JQuery 中进行验证的方式。我没有静态列出每个输入元素上的所有验证规则,而是设置了许多类。然后,在加载时,我会使用 JQuery 的 DOM 搜索功能来查找具有特定类集的每个输入元素,并动态添加适当的验证功能。

XAML 提供了一种非常好的方式来为显示元素提供这种简洁的配置,使用样式和 setter 。但这不适用于绑定(bind)。

有没有合理的替代方案?

最佳答案

简短的回答:不,不是。

但是你可以做两件事:

  • 你可以把
        NotifyOnValidationError="True"
    ValidatesOnDataErrors="True"
    UpdateSourceTrigger="PropertyChanged"

  • 在资源中并以 StaticResource 的身份访问它们,以排除冗余信息,然后您可以在一个地方更改所有这些属性。
  • 您可以自己制作markup extension基于绑定(bind)。这将使 XAML 声明更短。你可以像这样使用它:<TextBox Text={local:DecimalBinding Path=qtyoffset} />

  • 高温下,

    呸。

    关于wpf - 是否有在 XAML 中应用 Binding.ValidationRules 的简洁方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10144191/

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