如何在 MVC 4 中使用 jquery 验证表单的隐藏输入字段?

Posted

技术标签:

【中文标题】如何在 MVC 4 中使用 jquery 验证表单的隐藏输入字段?【英文标题】:How to Validating hidden input field of a form using jquery in MVC 4? 【发布时间】:2013-07-02 20:06:03 【问题描述】:

我正在尝试验证 mvc4 中表单的隐藏输入字段,但我失败了。我尝试了几种方法,但每次都失败了。我在谷歌搜索并得到了一些结果,但这些在我的情况下不起作用。有我正在尝试的代码

@using (html.BeginForm("NewSku","Product"))

@Html.AntiForgeryToken()
<label>Company Name :</label>
@(Html.Kendo().ComboBoxFor(x => x.CompanyId)
      .Name("CompanyId")
      .DataValueField("Id")
      .DataTextField("CompanyName")
      .Placeholder("Select Company")
      .Filter(FilterType.Contains)
      .DataSource(source => source.Read(read => read.Action("GetAllCompanys", "Product"))))
<br />
<label>Brand Name :</label>
@(Html.Kendo().ComboBoxFor(x => x.BrandId)
    .Name("BrandId")
    .DataTextField("BrandName")
    .DataValueField("Id")
    .Placeholder("Select Brand")
    .DataSource(source => source.Read(read => read.Action("GetAllBrandsByCompany", "Product").Data("filterBrand")).ServerFiltering(true))
    .AutoBind(false)
    .CascadeFrom("company"))
<br />
<label>Product Name :</label>
@(Html.Kendo().ComboBoxFor(x => x.ProductId)
    .HtmlAttributes(new  style = "Id=ProductComboBox" )
    .Name("ProductId")
    .DataTextField("ProductName")
    .DataValueField("Id")
    .Placeholder("Select Product")
    .DataSource(source => source.Read(read => read.Action("GetAllProductsByBrand", "Product").Data("filterProduct")).ServerFiltering(true))
    .AutoBind(false)
    .CascadeFrom("brand"))
<br />
<label>Sku Name :</label>
@(Html.Kendo().ComboBoxFor(x => x.SkuId)
    .Name("SkuId")
    .HtmlAttributes(new  style = "Id=SkuComboBox" )
    .DataTextField("SkuName")
    .DataValueField("Id")
    .Placeholder("Select Sku")
    .DataSource(source => source.Read(read => read.Action("GetAllSkusByProduct", "Product").Data("filerSku")).ServerFiltering(true))
        .AutoBind(false)
    .CascadeFrom("product"))
<br />

<span id="ErrorMessagess" class="alert-error">

</span>

@Html.HiddenFor(x => x.CompanyName)
@Html.ValidationMessageFor(x=>x.CompanyName)
@Html.HiddenFor(x => x.BrandName)
@Html.ValidationMessageFor(x=>x.BrandName)

@Html.HiddenFor(x => x.ProductName)
@Html.ValidationMessageFor(x=>x.ProductName)
@Html.HiddenFor(x => x.SkuName)
@Html.ValidationMessageFor(x=>x.SkuName)

<input type="submit" class="k-button keep-right" value="Update" />
@Html.ValidationSummary(true)


<script src="~/Scripts/jquery.validate.min.js"></script>
<script src="~/Scripts/jquery.validate.unobtrusive.min.js"></script>
<script>

$(document).ready(function () 
    //$('form').validate().settings.ignore = [];

    //$('form').validate(
    //    rules: 
    //        CompanyName: 
    //            required: true
    //        ,
    //        BrandName: 
    //            required: true
    //        
    //    
    //);


);

$('form').submit(function (e) 

    var validator = $('form').data('validator');
    validator.settings.ignore = "";

    var errorList = $('form').validate().errorList;

    console.log(errorList);

    $("form").validate().form();
    var form = $(this);

    $("#CompanyName").val($("#CompanyId").data("kendoComboBox").text());
    $("#BrandName").val($("#BrandId").data("kendoComboBox").text());
    $("#ProductName").val($("#ProductId").data("kendoComboBox").text());
    $("#SkuName").val($("#SkuId").data("kendoComboBox").text());

    $.ajax(
        url: form.attr("action"),
        type: 'POST',
        contentType: 'application/json; charset=utf-8',
        dataType: 'json',
        data: JSON.stringify($('form').serializeJSON()),
        success: function (result) 
            // console.log(result);
            $("#ErrorMessagess").val(result);
            return;
        
    );
    e.preventDefault();
);

我在挑衅做错事,但我不明白我做错了什么。

【问题讨论】:

【参考方案1】:

您必须执行/添加此操作才能验证隐藏输入:

$(document).ready(function () 
 $.validator.setDefaults(
        ignore: ""
    );
);

【讨论】:

我做到了,但它不起作用!真的,当用户提交表单并且我的隐藏字段为空时,我需要显示正确的消息。我正在使用 Html.ValidationMeesageFor。添加把你回答的脚本,但它仍然不起作用。你能帮我吗?

以上是关于如何在 MVC 4 中使用 jquery 验证表单的隐藏输入字段?的主要内容,如果未能解决你的问题,请参考以下文章

使用 jQuery 1.10.2 在 MVC 4 中进行客户端验证

mvc3 + jQuery 验证:如何捕获错误或正常事件

必填字段验证在 JQuery Popup MVC 4 中不起作用

必填字段验证在 JQuery Popup MVC 4 中不起作用

必填字段验证在 JQuery Popup MVC 4 中不起作用

必填字段验证在 JQuery Popup MVC 4 中不起作用