我已经按照Internet中的步骤设置了密码验证。ASP MVC4 + JQuery验证不起作用
我使用ASP.NET MVC4 +剃刀+ jQuery的,但验证好像不work.Here是我的代码:
CSHTML:
@using (Html.BeginForm("Index","Home",FormMethod.Post,new { id="resetForm"}))
{
<ol class="round">
<li class="one">
<h5>Select the Application.</h5>
@model PWDManagementCenter.Models.UserApplicationModels
@Html.DropDownListFor(x => x.selectedUserApp, Model.userApps)
</li>
<li class="two">
<h5>Input Login ID of Application</h5>
<input name="txtLogonId" />
</li>
<li class="three">
<h5>Input the new password</h5>
<input id="txtPwd" name="txtPwd" type="password" />
<h6>Retype the password</h6>
<input id="txtPwd2" name="txtPwd2" type="password" /><p />
<input id="btnSubmit" type="submit" value="Save" />
</li>
</ol>
}
JS在HTML:
<script src="/Scripts/jquery-1.7.1.js" type="text/javascript" />
<script src="/Scripts/jquery.validate.js" type="text/javascript" />
<script type="text/javascript">
$(document).ready(function() {
$('#resetForm').validate({
rules: {
txtPwd: {
require: true, minlength: 6, maxlength: 20
},
txtPwd2: {
require: true, equalTo: '#txtPwd', minlength: 6, maxlegth: 20
}
},
messages: {
txtPwd: {
require: "Password is required!",
minlength: "Password contains at least 6 characters",
maxlength: "Password contains at most 20 characters"
},
txtPwd2: {
equalTo: "Make sure input the same password as above"
}
}
});
</script>
而且控制器:
[HttpPost]
public ActionResult Index(UserApplicationModels model)
{
string appName = model.selectedUserApp;
string id = Request.Form["txtLogonId"];
string newPwd = Request.Form["txtPwd"];
string newPwd2 = Request.Form["txtPwd2"];
......
}
当我在调试模式下单击提交按钮时,它会跳到此索引函数而无需验证。
为什么?我错过了什么?请帮忙。
我按照这个简单的验证demo
感谢那些谁回答了这个问题。你给了我点击来解决问题。
脚本标签应以“
</script>
”,而不是“/>
” 所以这个“<script src="/Scripts/jquery.validate.js" type="text/javascript" />
”不能工作 结束,但这个“<script src="/Scripts/jquery.validate.js" type="text/javascript" ></script>
”的作品1后,我得到了一个运行时错误,说“jscript运行时错误对象不支持这个属性或方法” 这是因为我们包含jquery两次。
1,2后,验证是正常的。
你有没有考虑不显眼的验证(http://bradwilson.typepad.com /blog/2010/10/mvc3-unobtrusive-validation.html)?不回答你的问题,但使处理客户端和服务器验证非常容易。 – HackedByChinese
这不是我想要的。请参阅我的演示链接。这是简单而纯粹的jQuery。这就是我想要的 – DerekY
我明白你想要什么,只是一个供参考。 UV使用jQuery和jQuery验证,它只是增加了jQuery验证,所以你不必做你现在挣扎的手动布线。 – HackedByChinese