Exportar (0) Imprimir
Expandir todo
Este artículo se tradujo de forma manual. Mueva el puntero sobre las frases del artículo para ver el texto original.
Traducción
Original

ValidationRule (Clase)

Permite crear una regla personalizada para comprobar la validez de los datos proporcionados por el usuario.

Espacio de nombres:  System.Windows.Controls
Ensamblado:  PresentationFramework (en PresentationFramework.dll)

public abstract class ValidationRule

El tipo ValidationRule expone los siguientes miembros.

  NombreDescripción
Método protegidoValidationRule()Inicializa una nueva instancia de la clase ValidationRule.
Método protegidoValidationRule(ValidationStep, Boolean)Inicializa una nueva instancia de la clase ValidationRule con el paso de validación especificado y un valor que indica si la regla de validación se ejecuta cuando se actualiza el destino.
Arriba

  NombreDescripción
Propiedad públicaValidatesOnTargetUpdatedObtiene o establece un valor que indica si la regla de validación se ejecuta cuando se actualiza el destino de Binding.
Propiedad públicaValidationStepObtiene o establece cuándo se ejecuta la regla de validación.
Arriba

  NombreDescripción
Método públicoEquals(Object)Determina si el objeto Object especificado es igual al objeto Object actual. (Se hereda de Object).
Método protegidoFinalize Permite que un objeto intente liberar recursos y realizar otras operaciones de limpieza antes de ser reclamado por la recolección de elementos no utilizados. (Se hereda de Object).
Método públicoGetHashCodeActúa como función hash para un tipo concreto. (Se hereda de Object).
Método públicoGetType Obtiene el Type de la instancia actual. (Se hereda de Object).
Método protegidoMemberwiseClone Crea una copia superficial del Object actual. (Se hereda de Object).
Método públicoToString Retorna una cadena que representa al objeto actual. (Se hereda de Object).
Método públicoValidateCuando se invalida en una clase derivada, realiza comprobaciones de validación en un valor.
Arriba

Cuando se usa el modelo de enlace de datos de WPF, se puede asociar la propiedad ValidationRules al objeto de enlace. Para crear reglas personalizadas, cree una subclase de esta clase e implemente el método Validate. Opcionalmente, utilice la clase ExceptionValidationRule integrada, que detecta las excepciones que se producen durante las actualizaciones de origen, o bien, la clase DataErrorValidationRule, que comprueba los errores generados por la implementación de IDataErrorInfo del objeto de origen.

El motor de enlaces comprueba cada clase ValidationRule asociada a un enlace cada vez que transfiere un valor de entrada, que es el valor de propiedad del destino de enlace, a la propiedad del origen de enlace.

Para obtener información detallada sobre la validación de datos, vea Información general sobre el enlace de datos.

Para obtener información sobre cómo validar los datos proporcionados por el usuario en un cuadro de diálogo, vea Información general sobre cuadros de diálogo.

En el ejemplo siguiente se muestra cómo implementar una regla de validación. El valor de entrada no es válido si contiene caracteres no numéricos o si está fuera de los límites inferior y superior. Si el valor devuelto de ValidationResult no es válido, la propiedad ErrorContent se establece en el mensaje de error apropiado y la propiedad IsValid se establece en false.

Para obtener el ejemplo completo, vea Cómo: Implementar la validación de enlaces.


public class AgeRangeRule : ValidationRule
{
    private int _min;
    private int _max;

    public AgeRangeRule()
    {
    }

    public int Min
    {
        get { return _min; }
        set { _min = value; }
    }

    public int Max
    {
        get { return _max; }
        set { _max = value; }
    }

    public override ValidationResult Validate(object value, CultureInfo cultureInfo)
    {
        int age = 0;

        try
        {
            if (((string)value).Length > 0)
                age = Int32.Parse((String)value);
        }
        catch (Exception e)
        {
            return new ValidationResult(false, "Illegal characters or " + e.Message);
        }

        if ((age < Min) || (age > Max))
        {
            return new ValidationResult(false,
              "Please enter an age in the range: " + Min + " - " + Max + ".");
        }
        else
        {
            return new ValidationResult(true, null);
        }
    }
}


.NET Framework

Compatible con: 4, 3.5, 3.0

.NET Framework Client Profile

Compatible con: 4, 3.5 SP1

Windows 7, Windows Vista SP1 o posterior, Windows XP SP3, Windows Server 2008 (no se admite Server Core), Windows Server 2008 R2 (se admite Server Core con SP1 o posterior), Windows Server 2003 SP2

.NET Framework no admite todas las versiones de todas las plataformas. Para obtener una lista de las versiones compatibles, vea Requisitos de sistema de .NET Framework.

Todos los miembros static (Shared en Visual Basic) públicos de este tipo son seguros para la ejecución de subprocesos. No se garantiza que los miembros de instancias sean seguros para la ejecución de subprocesos.

Adiciones de comunidad

AGREGAR
Mostrar:
© 2014 Microsoft