不显眼的验证/ jQuery客户端验证输入的日期是否超过当前日期

时间:2022-12-09 19:29:45

I have a Date field , and I would like to verify that this date is higher than today's date.

我有一个日期字段,我想验证此日期是否高于今天的日期。

<script>
    jQuery.validator.addMethod("currentdate", function (value, element) {
        return Date.parse(value) > Date.parse(new Date());
    }, jQuery.validator.format("Date invalid"));
</script>

    @Html.LabelFor(m=>m.booking.Date)
    @Html.TextBoxFor(m => m.booking.Date, new { @class = "form-control", @id="Date" })
    @Html.ValidationMessageFor(m=>m.booking.Date)

What is the approach to take ? How do I have to structure my html helper ?

采取什么方法?我如何构建我的html帮助器?

1 个解决方案

#1


0  

Assuming the following form with a text box called Date:

假设以下表单带有一个名为Date的文本框:

@model TestFormViewModel

@{
    ViewBag.Title = "Index";
    HtmlHelper.ClientValidationEnabled = true;
    HtmlHelper.UnobtrusiveJavaScriptEnabled = true;
}

<h2>Test Form</h2>

@using (Html.BeginForm())
{
    @Html.TextBoxFor(x => x.Date)
    @Html.ValidationMessageFor(x => x.Date)
    <input type="submit" value="Submit" />
}

@section scripts {  
    <script src="~/Scripts/jquery-1.10.2.js"></script>
    <script src="~/Scripts/jquery.validate.js"></script>
    <script src="~/Scripts/jquery.validate-vsdoc.js"></script>
    <script src="~/Scripts/jquery.validate.unobtrusive.js"></script>
    <script src="~/Scripts/jquery.unobtrusive-ajax.js"></script>
    <script src="~/Scripts/validationrule.js"></script>
}

Simple controller action:

简单控制器动作:

[HttpPost]
public ActionResult Index(TestFormViewModel requestResponsemodel)
{
    return View(requestResponsemodel);
}

A JavaScript file included into the page called validationrule.js:

一个名为validationrule.js的页面中包含一个JavaScript文件:

$.validator.unobtrusive.adapters.add("currentdate", [], function (options) {
    options.rules['currentdate'] = options.params;
    if (options.message) {
        options.messages['currentdate'] = options.message;
    }
});

$.validator.addMethod("currentdate",
    function (value, element, other) {

        return Date.parse(value) > Date.parse(new Date());
    }
);

DateValidationAttribute.cs containing your server side validation:

包含服务器端验证的DateValidationAttribute.cs:

[AttributeUsage(AttributeTargets.Field | AttributeTargets.Property)]
public class CurrentDateValidationAttribute : ValidationAttribute, IClientValidatable
{

    // Default error message, can be overridden in the use of the attribute on your model
    public CurrentDateValidationAttribute() : base("The date must be later than the current date.")
    {
    }

    public override bool IsValid(object value)
    {
        var dateToValidate = (DateTime)value;
        return dateToValidate > DateTime.UtcNow;
    }

    // Client-Side validation 
    public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ModelMetadata metadata, ControllerContext context)
    {
        var rule = new ModelClientCurrentDateValidationRule("The date must be later than the current date.");
        yield return rule;
    }
}

... and a ModelClientValidationRule that will put the error message into the output of your Html helper (@Html.TextBoxFor()) to be picked up on the client side by your JavaScript validation code:

...以及一个ModelClientValidationRule,它将错误消息放入您的Html帮助器(@ Html.TextBoxFor())的输出中,以便在您的JavaScript验证代码中在客户端获取:

public class ModelClientCurrentDateValidationRule : ModelClientValidationRule
{
    public ModelClientCurrentDateValidationRule(string errorMessage)
    {
        ErrorMessage = errorMessage;
        ValidationType = "currentdate";
    }
}

The model to validate with the custom validation attribute assigned to your model, in this case the Date property:

要使用分配给模型的自定义验证属性进行验证的模型,在本例中为Date属性:

public class TestFormViewModel
{
    [CurrentDateValidation(ErrorMessage = "The date must be later than the current date.")]
    public DateTime Date { get; set; }
}

Your date field will validate on the client site as invalid when the date contained in the field is before the current date, like so:

当字段中包含的日期在当前日期之前时,您的日期字段将在客户端站点上验证为无效,如下所示:

不显眼的验证/ jQuery客户端验证输入的日期是否超过当前日期

#1


0  

Assuming the following form with a text box called Date:

假设以下表单带有一个名为Date的文本框:

@model TestFormViewModel

@{
    ViewBag.Title = "Index";
    HtmlHelper.ClientValidationEnabled = true;
    HtmlHelper.UnobtrusiveJavaScriptEnabled = true;
}

<h2>Test Form</h2>

@using (Html.BeginForm())
{
    @Html.TextBoxFor(x => x.Date)
    @Html.ValidationMessageFor(x => x.Date)
    <input type="submit" value="Submit" />
}

@section scripts {  
    <script src="~/Scripts/jquery-1.10.2.js"></script>
    <script src="~/Scripts/jquery.validate.js"></script>
    <script src="~/Scripts/jquery.validate-vsdoc.js"></script>
    <script src="~/Scripts/jquery.validate.unobtrusive.js"></script>
    <script src="~/Scripts/jquery.unobtrusive-ajax.js"></script>
    <script src="~/Scripts/validationrule.js"></script>
}

Simple controller action:

简单控制器动作:

[HttpPost]
public ActionResult Index(TestFormViewModel requestResponsemodel)
{
    return View(requestResponsemodel);
}

A JavaScript file included into the page called validationrule.js:

一个名为validationrule.js的页面中包含一个JavaScript文件:

$.validator.unobtrusive.adapters.add("currentdate", [], function (options) {
    options.rules['currentdate'] = options.params;
    if (options.message) {
        options.messages['currentdate'] = options.message;
    }
});

$.validator.addMethod("currentdate",
    function (value, element, other) {

        return Date.parse(value) > Date.parse(new Date());
    }
);

DateValidationAttribute.cs containing your server side validation:

包含服务器端验证的DateValidationAttribute.cs:

[AttributeUsage(AttributeTargets.Field | AttributeTargets.Property)]
public class CurrentDateValidationAttribute : ValidationAttribute, IClientValidatable
{

    // Default error message, can be overridden in the use of the attribute on your model
    public CurrentDateValidationAttribute() : base("The date must be later than the current date.")
    {
    }

    public override bool IsValid(object value)
    {
        var dateToValidate = (DateTime)value;
        return dateToValidate > DateTime.UtcNow;
    }

    // Client-Side validation 
    public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ModelMetadata metadata, ControllerContext context)
    {
        var rule = new ModelClientCurrentDateValidationRule("The date must be later than the current date.");
        yield return rule;
    }
}

... and a ModelClientValidationRule that will put the error message into the output of your Html helper (@Html.TextBoxFor()) to be picked up on the client side by your JavaScript validation code:

...以及一个ModelClientValidationRule,它将错误消息放入您的Html帮助器(@ Html.TextBoxFor())的输出中,以便在您的JavaScript验证代码中在客户端获取:

public class ModelClientCurrentDateValidationRule : ModelClientValidationRule
{
    public ModelClientCurrentDateValidationRule(string errorMessage)
    {
        ErrorMessage = errorMessage;
        ValidationType = "currentdate";
    }
}

The model to validate with the custom validation attribute assigned to your model, in this case the Date property:

要使用分配给模型的自定义验证属性进行验证的模型,在本例中为Date属性:

public class TestFormViewModel
{
    [CurrentDateValidation(ErrorMessage = "The date must be later than the current date.")]
    public DateTime Date { get; set; }
}

Your date field will validate on the client site as invalid when the date contained in the field is before the current date, like so:

当字段中包含的日期在当前日期之前时,您的日期字段将在客户端站点上验证为无效,如下所示:

不显眼的验证/ jQuery客户端验证输入的日期是否超过当前日期