如何在 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 中进行客户端验证
必填字段验证在 JQuery Popup MVC 4 中不起作用
必填字段验证在 JQuery Popup MVC 4 中不起作用