Binding.ValidatesOnDataErrors Eigenschaft
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
Dient zum Abrufen oder Festlegen eines Werts, der angibt, ob die DataErrorValidationRule.
public:
property bool ValidatesOnDataErrors { bool get(); void set(bool value); };
public bool ValidatesOnDataErrors { get; set; }
member this.ValidatesOnDataErrors : bool with get, set
Public Property ValidatesOnDataErrors As Boolean
Eigenschaftswert
trueum die DataErrorValidationRule; andernfalls einzuschließen. false
Beispiele
In den folgenden Beispielen wird IDataErrorInfo die ValidatesOnDataErrors Benutzereingabe in einem TextBox. Im ersten Beispiel wird ein Datentyp erstellt, der zum Melden von Überprüfungsfehlern IDataErrorInfo implementiert wird.
public class PersonImplementsIDataErrorInfo : IDataErrorInfo
{
private int age;
public int Age
{
get { return age; }
set { age = value; }
}
public string Error
{
get
{
return "";
}
}
public string this[string name]
{
get
{
string result = null;
if (name == "Age")
{
if (this.age < 0 || this.age > 150)
{
result = "Age must not be less than 0 or greater than 150.";
}
}
return result;
}
}
}
Public Class PersonImplementsIDataErrorInfo
Implements System.ComponentModel.IDataErrorInfo
Private m_age As Integer
Public Property Age() As Integer
Get
Return m_age
End Get
Set(ByVal value As Integer)
m_age = value
End Set
End Property
Public ReadOnly Property [Error]() As String _
Implements System.ComponentModel.IDataErrorInfo.Error
Get
Return ""
End Get
End Property
Default Public ReadOnly Property Item(ByVal name As String) As String _
Implements System.ComponentModel.IDataErrorInfo.Item
Get
Dim result As String = Nothing
If name = "Age" Then
If Me.m_age < 0 OrElse Me.m_age > 150 Then
result = "Age must not be less than 0 or greater than 150."
End If
End If
Return result
End Get
End Property
End Class
Das folgende Beispiel bindet die Age Eigenschaft an die TextBox und legt sie ValidatesOnDataErrorstrue für die Binding. Wenn der Benutzer einen ungültigen Wert eingibt, wird in der TextBox Fehlermeldung ToolTip ein roter Rahmen angezeigt.
<StackPanel Margin="20">
<StackPanel.Resources>
<src:PersonImplementsIDataErrorInfo x:Key="data"/>
<!--The tool tip for the TextBox to display the validation error message.-->
<Style x:Key="textBoxInError" TargetType="TextBox">
<Style.Triggers>
<Trigger Property="Validation.HasError" Value="true">
<Setter Property="ToolTip"
Value="{Binding RelativeSource={x:Static RelativeSource.Self},
Path=(Validation.Errors)[0].ErrorContent}"/>
</Trigger>
</Style.Triggers>
</Style>
</StackPanel.Resources>
<TextBlock>Enter your age:</TextBlock>
<TextBox Style="{StaticResource textBoxInError}">
<TextBox.Text>
<!--ValidatesOnDataErrors to is set to True, so the Binding
checks for errors raised by the IDataErrorInfo object.
An alternative syntax is to add <DataErrorValidationRule/> within
the <Binding.ValidationRules> section.-->
<Binding Path="Age" Source="{StaticResource data}"
ValidatesOnDataErrors="True"
UpdateSourceTrigger="PropertyChanged">
</Binding>
</TextBox.Text>
</TextBox>
<TextBlock>Mouse-over to see the validation error message.</TextBlock>
</StackPanel>
Hinweise
Das Festlegen dieser Eigenschaft bietet eine Alternative zur expliziten Verwendung des DataErrorValidationRule Elements. Dies DataErrorValidationRule ist eine integrierte Gültigkeitsprüfungsregel, die auf Fehler überprüft, die durch die IDataErrorInfo Implementierung des Quellobjekts ausgelöst werden. Wenn ein Fehler ausgelöst wird, erstellt das Bindungsmodul einen ValidationError mit dem Fehler und fügt ihn der Validation.Errors Auflistung des gebundenen Elements hinzu. Das Fehlen eines Fehlers löscht dieses Überprüfungsfeedback, es sei denn, eine andere Regel löst ein Überprüfungsproblem aus.
ValidatesOnDataErrors wird in der .NET Framework Version 3.5 eingeführt. Weitere Informationen finden Sie unter .NET Framework-Versionen und -Abhängigkeiten.