我有一个需要运行的简单Javascript文件。我知道它被渲染得很好,因为输入掩蔽部分工作得很好。但是,当我输入信息时,表单不会验证。例如,如果我输入4位数的电话号码,然后检查验证,则返回“true”。它不使用不显眼的验证。该项目是一个简单的ASP.NEt MVC网站,该网站是在Visual Studio Enterprise 2015平台上编写的。网站上的相关页面是EditInfo页面,供您参考。必须设置一些变量才能使其工作,但我不知道它是什么。感谢您的帮助,祝您度过愉快的一天。
首先,这是BundleConfig.cs文件。这部分(不是整个文件)是jquery.validate插件。
bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include(
"~/Scripts/jquery.validate*",
"~/Scripts/additional-methods.js",
"~/Scripts/additional-methods.min.js",
"~/Scripts/jquery.validate.js",
"~/Scripts/jquery.selectric.js",
"~/Scripts/jquery.validate.min.js"));
捆绑包在布局页面中呈现。
@Scripts.Render("~/bundles/jqueryval")
app.js文件包含错误放置中使用的函数以及jquery.validator默认设置。
if ($.validator) {
jQuery.validator.setDefaults({
invalidHandler: function (form, validator) {
if (!validator.numberOfInvalids())
return;
$('html, body').animate({
scrollTop: $(validator.errorList[0].element).offset().top - 150
}, 'fast');
$(validator.errorList[0].element).focus();
},
onkeyup: false
});
}
//
// Name: errorPlacementValidator
// Description: Used by the validator.
//
function errorPlacementValidator(error, element) {
if (element.is(":radio")) {
error.appendTo(element.closest("[class*='col-sm-']"));
}
else if (element.parents('.selectric-wrapper').size() > 0) {
console.log('selectric error');
error.appendTo(element.closest('[class*="col-sm-"]'));
}
else {
error.appendTo(element.parent());
}
}
//
// Name: highlight
// Description: Used by the validator to show the error messages.
//
function highlightValidator(element, errorClass, validClass, counter) {
var $parent = $(element).parent();
// remove icon and success spans if any
$parent.find("span.form-control-feedback, span.sr-only").remove();
// add ".error" class to input element
$(element).addClass(errorClass).removeClass(validClass);
// add Bootstrap ".has-error" class to parent div.form-group element
$(element).closest(".form-group").removeClass("has-success").addClass("has-error has-feedback");
// need to have it check to see if span already added
// only add for non radio or non select input elements
if (!$(element).is(":radio, select, textarea, :checkbox, .btn") && !$(element).hasClass("datepicker")) {
counter++;
var $spans = $parent.find("span");
// check to make sure error spans are not already in form-group before attempting to append after input
if ($spans.length == 0) {
// add span element with ".glyphicon" ".glyphicon-remove" ".form-control-feedback" classes after input
$(element).after("<span class='glyphicon glyphicon-remove form-control-feedback' aria-hidden='true'></span>");
$(element).after("<span id='inputError" + counter + "Status'" + " class='sr-only'>(error)</span>");
}
}
}
//
// Name: unhighlightValidator
// Description: Used by the validator to hide the error messages.
//
function unhighlightValidator(element, errorClass, validClass, counter) {
var $parent = $(element).parent();
// remove icon and success spans if any
$parent.find("span.form-control-feedback, span.sr-only").remove();
// remove ".error" class from input element
$(element).removeClass(errorClass).addClass(validClass);
if (!$(element).is(":radio, select, textarea, :checkbox, .btn") && !$(element).hasClass("datepicker")) {
// // remove Bootstrap ".has-error" class from parent div.form-group element
$(element).closest(".form-group").removeClass("has-error").addClass("has-success has-feedback");
var $spans = $parent.find("span");
if ($spans.length == 0 && !$(element).is("select")) {
$(element).after("<span class='glyphicon glyphicon-ok form-control-feedback' aria-hidden='true'></span>");
$(element).after("<span id='inputSuccess" + counter + "Status'" + " class='sr-only'>(error)</span>");
}
} else if ($(element).parents('.selectric-wrapper').size() > 0) {
$(element).closest(".form-group").removeClass("has-error").addClass("has-success has-feedback");
}
}
这是EditInfo.cshtml文件脚本部分。
@section scripts {
@Scripts.Render("~/bundles/jqueryval")
<script src="@Url.Content("~/Scripts/EditInfo.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/app.js")" type="text/javascript"></script>
}
部分scripts
在布局文件中呈现。
@RenderSection("scripts", required: false)
接下来是EditInfo.cshtml页面。这是一个示例,第一个项目,在本例中是一个文本框。表格标签在结尾处关闭,没有输入。 javascript文件确实使用名称,而不是元素的id。
<div class="frontpage">
<form class="form-horizontal" id="frmEditInfo" name="frmEditInfo">
<div class="row">
<div class="col-sm-6">
<div class="form-group">
<label for="workCell" class="col-sm-4 control-label">Work Cellphone</label>
<div class="col-sm-6">
<input type="tel" name="workCell" id="workCell" class="form-control" placeholder="Work Cellphone">
</div>
</div>
</div>
最后,这是实际的javascript文件EditInfo.js
$(document).ready(function () {
var counter = 0;
$("#frmEditInfo").validate({
ignore: [],
rules: {
personalEmail:{
email: true
//pattern: /^([a-zA-Z0-9_\-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([a-zA-Z0-9\-]+\.)+))([a-zA-Z]{2,15}|[0-9]{1,3})(\]?)$/i
},
otherEmail: {
email: true
//pattern: /^([a-zA-Z0-9_\-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([a-zA-Z0-9\-]+\.)+))([a-zA-Z]{2,15}|[0-9]{1,3})(\]?)$/i
},
workCell: {
required: true,
phoneUS: true
//pattern: /^\(?\d{3}\)?\s?-?\d{3}\s?-?\d{4}$/
},
personalCell: {
phoneUS: true
//pattern: /^\(?\d{3}\)?\s?-?\d{3}\s?-?\d{4}$/
},
otherPhone: {
phoneUS: true
//pattern: /^\(?\d{3}\)?\s?-?\d{3}\s?-?\d{4}$/
}
},
messages: {
personalEmail: {
email: "Invalid Email"
},
otherEmail: {
email: "Invalid Email"
},
workCell: {
phoneUS: "Invalid Phone Number"
},
personalCell: {
phoneUS: "Invalid Phone Number"
},
otherPhone: {
phoneUS: "Invalid Phone Number"
}
},
errorPlacement: function (error, element) {
errorPlacementValidator(error, element);
},
highlight: function (element, errorClass, validClass) {
counter++;
highlightValidator(element, errorClass, validClass, counter);
},
unhighlight: function (element, errorClass, validClass) {
counter++;
unhighlightValidator(element, errorClass, validClass, counter);
}
});
$('#workCell').inputmask("(999) 999-9999");
$('#personalCell').inputmask("(999) 999-9999");
$('#otherPhone').inputmask("(999) 999-9999");
});
编辑:删除了有关提交功能的不必要代码。
答案 0 :(得分:0)
我修好了。
TL; DR js文件未在BundleConfig.cs
经过大量研究后,我将代码放入jsfiddle中,并且有效。所以我回去确保我已经更新了JS文件等。最终我发现了问题,这是在BundleConfig文件中。包含jquery-validate.js
文件的捆绑包名称不正确。这并不是说这是唯一的问题,Sparky帮助我完成了我的规则(不是编写我自己的正则表达式),而是在我使用method.min.js
时不使用method.js
文件。我想我应该发布答案只是为了直接设置记录。