Binding.ValidatesOnExceptions Tulajdonság

Definíció

Lekéri vagy beállít egy értéket, amely jelzi, hogy a ExceptionValidationRule.

public:
 property bool ValidatesOnExceptions { bool get(); void set(bool value); };
public bool ValidatesOnExceptions { get; set; }
member this.ValidatesOnExceptions : bool with get, set
Public Property ValidatesOnExceptions As Boolean

Tulajdonság értéke

truea ; másként falsevaló belefoglalásáhozExceptionValidationRule.

Példák

Az alábbi példák a felhasználói bevitel ellenőrzésére használhatók ValidatesOnExceptions egy TextBox. Az első példa létrehoz egy adattípust, amely kivételt okoz, ha a Age tulajdonság értéke érvénytelen.

public class PersonThrowException
{
    private int age;

    public int Age
    {
        get { return age; }
        set
        {

            if (value < 0 || value > 150)
            {
                throw new ArgumentException("Age must not be less than 0 or greater than 150.");
            }
            age = value;
        }
    }
}
Public Class PersonThrowException
    Private m_age As Integer

    Public Property Age() As Integer
        Get
            Return m_age
        End Get
        Set(ByVal value As Integer)

            If value < 0 OrElse value > 150 Then
                Throw New ArgumentException("Age must not be less than 0 or greater than 150.")
            End If
            m_age = value
        End Set
    End Property
End Class

Az alábbi példa a tulajdonságot a Age következőhöz TextBox köti, és a következőhöz true állítja ValidatesOnExceptions be: Binding. Amikor a felhasználó érvénytelen értéket ad meg, piros szegély jelenik meg a TextBoxToolTip hibaüzenetben.

<StackPanel Margin="20">
  <StackPanel.Resources>
    
    <src:PersonThrowException 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>
      <!--By setting ValidatesOnExceptions to True, it checks for exceptions
        that are thrown during the update of the source property.
        An alternative syntax is to add <ExceptionValidationRule/> within
        the <Binding.ValidationRules> section.-->
      <Binding Path="Age" Source="{StaticResource data}"
               ValidatesOnExceptions="True"
               UpdateSourceTrigger="PropertyChanged">
      </Binding>
    </TextBox.Text>
  </TextBox>
  <TextBlock>Mouse-over to see the validation error message.</TextBlock>
</StackPanel>

Megjegyzések

A tulajdonság beállítása alternatívát kínál az ExceptionValidationRule elem explicit használatára. Ez ExceptionValidationRule egy beépített ellenőrzési szabály, amely ellenőrzi a forrástulajdonság frissítése során megjelenő kivételeket. Kivétel esetén a kötési motor létrehoz egy ValidationError kivételt, és hozzáadja azt a Validation.Errors kötött elem gyűjteményéhez. A hiba hiánya törli ezt az érvényesítési visszajelzést, kivéve, ha egy másik szabály érvényesítési problémát vet fel.

ValidatesOnExceptions a .NET-keretrendszer 3.5-ös verziójában kerül bevezetésre. További információ: .NET-keretrendszerverziók és -függőségek.

A következőre érvényes:

Lásd még