Estoy creando un validador de rango de día usando DataAnnotations, jQuery.validate y jquery.validate.unobtrusive. Ya he leído lo siguiente: http://bradwilson.typepad.com/blog/2010/10/mvc3-unobtrusive-validation.htmljQuery.validator.unobtrusive.adapters.addMinMax ida y vuelta, no funciona en MVC3
y otra, pero no puede publicarlos (novato)
Así como la mayor parte del mensaje el SO. Estoy Baning la cabeza contra una pared, cualquier ayuda podría rewardde con cerveza/comida/código/etc;) De todos modos aquí está el código:
Tengo un objeto de modelo con el siguiente parámetro:
[Display(Name = "Start date"),
DayRange(0, 5, ErrorMessage = "The Start Date must be between today and 5 days time.")]
public DateTime StartDate { get; set; }
DAYRANGE es una clase de atributo personalizado:
[AttributeUsage(AttributeTargets.Field | AttributeTargets.Property, AllowMultiple = false, Inherited = true)]
public class DayRangeAttribute : RangeAttribute, IClientValidatable
{
private int _minimumDays;
private int _maximumDays;
public DayRangeAttribute(int minimumDays, int maximumDays) : base(minimumDays, maximumDays)
{
_minimumDays = minimumDays;
_maximumDays = maximumDays;
}
public override bool IsValid(object value)
{
var dateToBeTested = value as DateTime?;
return dateToBeTested.HasValue && dateToBeTested.Value >= DateTime.Today.AddDays(_minimumDays) && dateToBeTested.Value <= DateTime.Today.AddDays(_maximumDays);
}
public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ModelMetadata metadata, ControllerContext context)
{
var rule = new ModelClientValidationRule
{
ErrorMessage = this.ErrorMessage,
ValidationType = "dayrange"
};
rule.ValidationParameters.Add("min", _minimumDays);
rule.ValidationParameters.Add("max", _maximumDays);
yield return rule;
}
}
tengo el siguiente en mi web.config:
<appSettings>
<add key="ClientValidationEnabled" value="true"/>
<add key="UnobtrusiveJavaScriptEnabled" value="true"/>
</appSettings>
He tienen siguiente trigger JS antes de que el documento está listo (tratado de disparo cuando el documento está listo también):
jQuery.validator.addMethod('dayrange', function (value, element, param) {
if (!value) return false;
var now = Date();
var dateValue = Date.parse(value);
var minDate = now.setDate(now.getDate() - param.min);
var maxDate = now.setDate(now.getDate() + param.max);
return this.optional(element) && dateValue >= minDate && dateValue <= maxDate;
}, 'Must fall in range');
jQuery.validator.unobtrusive.adapters.addMinMax('dayrange', 'minlength', 'maxlength', 'dayrange');
¿Qué estoy haciendo mal? Gracias de antemano, Jol
me ayudó! gracias :-) – Peter
Placer de placer. Me tomó horas encontrar que '(jQuery)' faltaba al final, espero que no hayas tomado tanto tiempo. – jolySoft
Estaba buscando cómo crear una función de validación personalizada utilizando la validación de jquery a la que puede pasar parámetros. ¡Y me has dado un buen ejemplo! – Peter