ValidationError Classe
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Representa um erro de validação que é criado pelo mecanismo de associação quando um ValidationRule relata um erro de validação ou por meio do método MarkInvalid(BindingExpressionBase, ValidationError) explicitamente.
public ref class ValidationError
public class ValidationError
type ValidationError = class
Public Class ValidationError
- Herança
-
ValidationError
Exemplos
O exemplo a seguir mostra um gatilho de estilo que cria um ToolTip que relata uma mensagem de erro de validação. A Validation.Errors propriedade anexada retorna uma coleção de ValidationError objetos no elemento associado.
<Style x:Key="textStyleTextBox" TargetType="TextBox">
<Setter Property="Foreground" Value="#333333" />
<Setter Property="MaxLength" Value="40" />
<Setter Property="Width" Value="392" />
<Style.Triggers>
<Trigger Property="Validation.HasError" Value="true">
<Setter Property="ToolTip"
Value="{Binding RelativeSource={RelativeSource Self},
Path=(Validation.Errors)[0].ErrorContent}"/>
</Trigger>
</Style.Triggers>
</Style>
Comentários
O modelo de associação de dados do WPF permite associar regras de validação ao seu Binding objeto. A validação ocorre durante a transferência de valor de destino para fonte antes que o conversor seja chamado. O conteúdo a seguir descreve o processo de validação.
Quando um valor está sendo transferido da propriedade de destino para a propriedade de origem, o mecanismo de associação de dados primeiro remove qualquer ValidationError um que possa ter sido adicionado à Validation.Errors propriedade anexada do elemento associado. Em seguida, ele verifica se alguma regra de validação personalizada é definida para esse Binding, nesse caso, ele chama o Validate método em cada ValidationRule até que uma delas falhe ou até que todas elas passem.
Depois que há uma regra personalizada que não passa, o mecanismo de associação cria um ValidationError objeto e o Validation.Errors adiciona à coleção do elemento associado. Quando Validation.Errors não estiver vazio, a Validation.HasError propriedade anexada do elemento será definida como
true
. Além disso, se a propriedade NotifyOnValidationError do Binding estiver definida comotrue
, o mecanismo de associação gerará o evento anexado Validation.Error no elemento.Se todas as regras forem aprovadas, o mecanismo de associação chamará o conversor, se houver uma.
Se o conversor for aprovado, o mecanismo de associação chamará o setter da propriedade de origem.
Se a associação tiver uma ExceptionValidationRule associada a ela e uma exceção for gerada durante a etapa 3 ou 4, o mecanismo de associação verificará se há um UpdateSourceExceptionFilter. Você pode usar o retorno de chamada UpdateSourceExceptionFilter para fornecer um manipulador personalizado para lidar com exceções. Se um UpdateSourceExceptionFilter não for especificado no , o Bindingmecanismo de associação criará um ValidationError com a exceção e o Validation.Errors adicionará à coleção do elemento associado.
Uma transferência de valor válida em qualquer direção (destino para origem ou origem para destino) limpará a Validation.Errors propriedade anexada.
Construtores
ValidationError(ValidationRule, Object, Object, Exception) |
Inicializa uma nova instância da classe ValidationError com os parâmetros especificados. |
ValidationError(ValidationRule, Object) |
Inicializa uma nova instância da classe ValidationError com os parâmetros especificados. |
Propriedades
BindingInError |
Obtém o objeto BindingExpression ou MultiBindingExpression deste ValidationError. O objeto é marcado como inválido explicitamente ou tem uma regra de validação com falha. |
ErrorContent |
Obtém ou define um objeto que fornece contexto adicional para este ValidationError, como uma cadeia de caracteres que descreve o erro. |
Exception |
Obtém ou define o objeto Exception que foi a causa deste ValidationError, se o erro foi o resultado de uma exceção. |
RuleInError |
Obtém ou define o objeto ValidationRule que foi a causa deste ValidationError, se o erro foi o resultado de uma regra de validação. |
Métodos
Equals(Object) |
Determina se o objeto especificado é igual ao objeto atual. (Herdado de Object) |
GetHashCode() |
Serve como a função de hash padrão. (Herdado de Object) |
GetType() |
Obtém o Type da instância atual. (Herdado de Object) |
MemberwiseClone() |
Cria uma cópia superficial do Object atual. (Herdado de Object) |
ToString() |
Retorna uma cadeia de caracteres que representa o objeto atual. (Herdado de Object) |