添加 MVC3 不显眼的验证 (addMinMax)

发布于 2024-11-09 13:47:57 字数 2326 浏览 5 评论 0原文

我有这样的属性:

public class AgeRangeAttribute:ValidationAttribute,IClientValidatable
    {
public int MinAge { get; set; }

        public int MaxAge { get; set; }

public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ModelMetadata metadata, ControllerContext context)
        {
            ModelClientValidationRule rule = new ModelClientValidationRule
                                                {
                                                    ErrorMessage = ErrorMessage,
                                                    ValidationType = "agerange"
                                                };
            if (MinAge != int.MinValue)
            {
                rule.ValidationParameters.Add("minage", DateTime.Now.AddYears(-MinAge).ToShortDateString());
            }
            if(MaxAge != int.MinValue)
            {
                rule.ValidationParameters.Add("maxage", DateTime.Now.AddYears(-MaxAge).ToShortDateString());
            }
            yield return rule;
        }
}

和 JS 验证器表示:

jQuery.validator.addMethod("agerangemin", function (value, element, param) {
    var date = setDate(new Date(),value);
    var expected = setDate(new Date(), param);
    return date <= expected;
});

jQuery.validator.addMethod("agerangemax", function (value, element, param) {
    var date = setDate(new Date(), value);
    var expected = setDate(new Date(), param);
    return date > expected;
});

jQuery.validator.addMethod("agerangemaxmin", function (value, element, param) {
    var date = setDate(new Date(), value);
    var expectedMin = setDate(new Date(), param[1]);
    var expectedMax = setDate(new Date(), param[0]);
    return date <= expectedMin && date > expectedMax;
});


jQuery.validator.unobtrusive.adapters.addMinMax("agerange", "agerangemin", "agerangemax", "agerangemaxmin");

并且这个 js 不起作用(没有例外......可能已经死了&:))

但这工作正常:

jQuery.validator.addMethod("agerange", function (value, element, param) {
    var date = new Date();
    date = setDate(date, value);
    var expected = setDate(new Date, param);
    return date <= expected;
});

jQuery.validator.unobtrusive.adapters.addSingleVal("agerange", "minage");

它有什么问题?哪里有错误?

I have such attribute:

public class AgeRangeAttribute:ValidationAttribute,IClientValidatable
    {
public int MinAge { get; set; }

        public int MaxAge { get; set; }

public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ModelMetadata metadata, ControllerContext context)
        {
            ModelClientValidationRule rule = new ModelClientValidationRule
                                                {
                                                    ErrorMessage = ErrorMessage,
                                                    ValidationType = "agerange"
                                                };
            if (MinAge != int.MinValue)
            {
                rule.ValidationParameters.Add("minage", DateTime.Now.AddYears(-MinAge).ToShortDateString());
            }
            if(MaxAge != int.MinValue)
            {
                rule.ValidationParameters.Add("maxage", DateTime.Now.AddYears(-MaxAge).ToShortDateString());
            }
            yield return rule;
        }
}

and JS validator representation:

jQuery.validator.addMethod("agerangemin", function (value, element, param) {
    var date = setDate(new Date(),value);
    var expected = setDate(new Date(), param);
    return date <= expected;
});

jQuery.validator.addMethod("agerangemax", function (value, element, param) {
    var date = setDate(new Date(), value);
    var expected = setDate(new Date(), param);
    return date > expected;
});

jQuery.validator.addMethod("agerangemaxmin", function (value, element, param) {
    var date = setDate(new Date(), value);
    var expectedMin = setDate(new Date(), param[1]);
    var expectedMax = setDate(new Date(), param[0]);
    return date <= expectedMin && date > expectedMax;
});


jQuery.validator.unobtrusive.adapters.addMinMax("agerange", "agerangemin", "agerangemax", "agerangemaxmin");

and this js doesn't work (no exceptions... may be dead& :) )

but this works fine:

jQuery.validator.addMethod("agerange", function (value, element, param) {
    var date = new Date();
    date = setDate(date, value);
    var expected = setDate(new Date, param);
    return date <= expected;
});

jQuery.validator.unobtrusive.adapters.addSingleVal("agerange", "minage");

Whats wrong with it? Where is mistake?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

清音悠歌 2024-11-16 13:47:57

一年前,我在自定义不引人注目的验证方面遇到了一些困难。这是我想出的。我需要创建验证器来检查用户是否年满十八岁。

我的代码:

public class CustomEiteenthValidator : ValidationAttribute, IClientValidatable
    {
        protected override ValidationResult IsValid(object value, ValidationContext validationContext)
        {
            if (value == null) return null;
            DateTime date = Convert.ToDateTime(value);
            var minDate = DateTime.Now.AddYears(-18);
            if (date > minDate) 
            return new ValidationResult("Employee should be more than 18 years");
            return null;
        }

        public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ModelMetadata metadata, ControllerContext context)
        {
            var rule = new ModelClientValidationRule()
            {
                ValidationType = "eiteenth",
                ErrorMessage = "Employee should be more than 18 years"
            };
            var date = DateTime.Now.AddYears(-18);
            rule.ValidationParameters["date"] = String.Format("{0:dd/MM/yyyy}", date).Replace('.', '/');
            yield return rule;
        }
    }

在模型中:

        [Required]
        [DataType(DataType.DateTime)]
        [CustomEiteenthValidator]            
        public DateTime Birthday { get; set; }

CustomDateValidation.js 中的一些 java 脚本代码:

 function isFormValid() {
        var valid = true;
        $('.field-validation-error').each(function () {
            valid = false;
        });
        return valid;
    }

(function ($) {
    $.validator.addMethod("eiteenthcheck", function (val, elem, params) {
        if (!val) {
            return false;
        }
        try {
            var birthday = $.datepick.parseDate("dd/mm/yyyy", val);
            var maxBirthday = $.datepick.parseDate("dd/mm/yyyy", $(elem).attr('data-val-eiteenth-date'));
        }
        catch (e) {
            return false;
        }
        if (maxBirthday.getTime() > birthday.getTime()) return true;
        return false;
    });

    $.validator.unobtrusive.adapters.add("eiteenth", ["date"], function (options) {
        options.rules["eiteenthcheck"] = 'eiteenthcheck';
        if (options.message) options.messages["eiteenthcheck"] = options.message;
    });
} (jQuery));

在视图中,我渲染文本框如下:

<%: Html.EditorFor(model => model.Birthday) %>
<%: Html.ValidationMessageFor(model => model.Birthday) %>

最后一个是我使用的脚本:

    <script src="<%= Url.Content("~/Scripts/jquery-1.7.1.min.js") %>" type="text/javascript"></script>   
    <script src="<%= Url.Content("~/Scripts/jquery.validate.js") %>" type="text/javascript"></script>
    <script src="<%= Url.Content("~/Scripts/jquery.validate.unobtrusive.js") %>" type="text/javascript"></script>
    <script src="<%= Url.Content("~/Scripts/jquery.datepick.js") %>" type="text/javascript"></script>
    <script src="<%= Url.Content("~/Scripts/CustomDateValidation.js") %>" type="text/javascript"></script>        

I have some difficulties with custom unobtrusive validation a year ago. Here is what I came up with. I needed to create validator that check if user is eighteen years old.

My code:

public class CustomEiteenthValidator : ValidationAttribute, IClientValidatable
    {
        protected override ValidationResult IsValid(object value, ValidationContext validationContext)
        {
            if (value == null) return null;
            DateTime date = Convert.ToDateTime(value);
            var minDate = DateTime.Now.AddYears(-18);
            if (date > minDate) 
            return new ValidationResult("Employee should be more than 18 years");
            return null;
        }

        public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ModelMetadata metadata, ControllerContext context)
        {
            var rule = new ModelClientValidationRule()
            {
                ValidationType = "eiteenth",
                ErrorMessage = "Employee should be more than 18 years"
            };
            var date = DateTime.Now.AddYears(-18);
            rule.ValidationParameters["date"] = String.Format("{0:dd/MM/yyyy}", date).Replace('.', '/');
            yield return rule;
        }
    }

In model:

        [Required]
        [DataType(DataType.DateTime)]
        [CustomEiteenthValidator]            
        public DateTime Birthday { get; set; }

And some java script code in CustomDateValidation.js:

 function isFormValid() {
        var valid = true;
        $('.field-validation-error').each(function () {
            valid = false;
        });
        return valid;
    }

(function ($) {
    $.validator.addMethod("eiteenthcheck", function (val, elem, params) {
        if (!val) {
            return false;
        }
        try {
            var birthday = $.datepick.parseDate("dd/mm/yyyy", val);
            var maxBirthday = $.datepick.parseDate("dd/mm/yyyy", $(elem).attr('data-val-eiteenth-date'));
        }
        catch (e) {
            return false;
        }
        if (maxBirthday.getTime() > birthday.getTime()) return true;
        return false;
    });

    $.validator.unobtrusive.adapters.add("eiteenth", ["date"], function (options) {
        options.rules["eiteenthcheck"] = 'eiteenthcheck';
        if (options.message) options.messages["eiteenthcheck"] = options.message;
    });
} (jQuery));

In view I render textbox like that:

<%: Html.EditorFor(model => model.Birthday) %>
<%: Html.ValidationMessageFor(model => model.Birthday) %>

The last one is scripts I use:

    <script src="<%= Url.Content("~/Scripts/jquery-1.7.1.min.js") %>" type="text/javascript"></script>   
    <script src="<%= Url.Content("~/Scripts/jquery.validate.js") %>" type="text/javascript"></script>
    <script src="<%= Url.Content("~/Scripts/jquery.validate.unobtrusive.js") %>" type="text/javascript"></script>
    <script src="<%= Url.Content("~/Scripts/jquery.datepick.js") %>" type="text/javascript"></script>
    <script src="<%= Url.Content("~/Scripts/CustomDateValidation.js") %>" type="text/javascript"></script>        
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文