<html>
<head>
<title> Form Validation </title>
<style type="text/css">
fieldset { width: 280px; padding: 6px; }
label { float: left; width: 100px; font: 12px Arial; padding: 5px; }
input { margin-bottom: 5px; }
</style>
</head>
<body>
<form id="inputForm" onsubmit="return validateForm();" action="#">
<fieldset>
<label>First Name:</label><input type="text" name="first_name" /><br />
<label>Surname:</label><input type="text" name="surname" /><br />
<label>Postcode:</label><input type="text" name="postcode" /><br />
<label>Email:</label><input type="text" name="email" /><br />
<input type="submit" name="submit" value="Send form" />
<input type="reset" name="reset" value="Reset" />
</fieldset>
</form>
<script type="text/javascript">
function validateForm() {
var form = document.forms['inputForm'];
var formats = {
First_name: /^[a-z]+[\-`\s]?[a-z]+$/i,
Surname: /^[a-z]+[\-`\S]?[a-z]+$/i,
Postcode: /^\d{4}$/,
Email:/^w+([\.-]?\w+)*@\w+([\.-]?\w+)*(\.\w{2,4})+$/
};
var elCount = form.elements.length;
for(var i = 0; i <elCount; i++) {
var field = form.elements[i];
if(field.type == 'text') {
if(!formats[field.name].test(field.value)) {
alert('Invalid '+field.name.replace('_', ' '));
field.focus();
return false;
}
}
}
}
</script>
</body>
</html>
嘿伙计们试图找出代码为什么会给我一个错误:underfinded formats [fields.Name]但是已经定义了。它只是一个简单的形式,所以我不确定我做错了什么。对不起基本问题,但我已多次查看它,看不到它。再次干杯。
答案 0 :(得分:0)
假设你所说的错误就在这一行:
if(!formats[field.Name].test(field.value)) {
我建议在“name”属性中使用小写“n”:
if(!formats[field.name].test(field.value)) {
JavaScript区分大小写。
更新:除了我已经提到的内容,但仍然是区分大小写,您的formats
对象具有混合大小写的属性名称,例如First_name
,但相应的输入元素具有name
属性为小写,例如name="first_name"
,因此当您检索元素的name
并尝试使用它来查找formats
中的属性时,它将返回{{1} }}。你需要做出那些匹配案例。
修正这些错误并且有效:http://jsfiddle.net/M4Nzr/