javascript - 表单提交,即使它没有通过 JavaScript 验证
问题描述
我正在制作一个简单的表格,并为每个字段制作了一个函数来验证。但是当我通过实时服务器测试表单时,即使字段未验证,表单也会提交。除此之外,每个功能似乎都按预期工作。
function validateForm () {
var firstName = document.getElementById('fname').value;
var phoneNumber = document.getElementById('phonenumber').value;
function firstNameValid () {
if (firstName == "") {
console.log("First name empty")
return false;
} else {
return true;
};
};
firstNameValid();
function phoneValid () {
if (phoneNumber == null || phoneNumber == "" || phoneNumber.length < 10) {
console.log("Phone number must be defined and not exceed 10 characters")
return false;
} else {
return true;
}
};
phoneValid();
result = firstNameValid() && phoneValid();
};
<body>
<form name="registration" action="page2.html" onsubmit="return validateForm()" method="GET">
<ul>
<li>
<label for="fname">First Name:</label><br>
<input type="text" id="fname" name="fname" onsubmit="return firstNameValid()"><br>
</li>
<li>
<label for="phonenumber">Phone Number:</label><br>
<input type="text" id="phonenumber" name="phonenumber" onsubmit="return phoneValid()">
</li>
</ul>
<button type="submit" value="Submit">Submit</button>
</form>
<script src="app.js"> </script>
</body>
解决方案
您没有返回结果变量
result = firstNameValid() && phoneValid();
return result;
推荐阅读
- angular - 使用货币管道在离子输入上无法按预期工作
- html - 外部尺寸确定(CSS 内部和外部尺寸模块第 3 级)
- java - 无法访问 org.jooq.TableField
- reactjs - 将 Aysnc/await 与 Props 一起使用
- django - 使用 Django Memcached 缓存 Zip 对象
- ios - 如何调试金属错误?(国际足联)
- python - PyQt5 QFileDialog setFont
- kotlin - 没有应用程序的Javafx文件选择器?(科特林)
- c# - 如何获取 Expression.Lambda
> 通用 - xml - 使用 XSLT 将所有未嵌套的 XML 元素嵌套到一个新元素中