JavaScript 教程
- 第1节:javascript 简介
- 第2节:JavaScript 用法
- 第3节:JavaScript 输出
- 第4节:JavaScript 语法
- 第5节:JavaScript 语句
- 第6节:JavaScript 注释
- 第7节:JavaScript 变量
- 第8节:JavaScript 数据类型
- 第9节:JavaScript 函数
- 第10节:JavaScript 作用域
- 第11节:JavaScript 事件
- 第12节:JavaScript 字符串
- 第13节:JavaScript 运算符
- 第14节:JavaScript 比较和逻辑运算符
- 第15节:JavaScript 位运算符
- 第16节:JavaScript if…else 语句
- 第17节:JavaScript switch 语句
- 第18节:JavaScript for 循环
- 第19节:JavaScript while 循环
- 第20节:JavaScript Break 和 Continue 语句
- 第21节:JavaScript 类型转换
- 第22节:JavaScript 正则表达式
- 第23节:JavaScript 错误处理(Throw、Try 和 Catch)
- 第24节:JavaScript 调试
- 第25节:JavaScript 表单验证
- 第26节:JavaScript 保留关键字
- 第27节:JavaScript JSON
- 第28节:javascript:void(0) 含义
- 第29节:JavaScript 代码规范
JavaScript 表单验证
JavaScript 可用来在数据被送往服务器前对 HTML 表单中的这些输入数据进行验证。
表单数据经常需要使用 JavaScript 来验证其正确性:
- 验证表单数据是否为空?
- 验证输入是否是一个正确的email地址?
- 验证日期是否输入正确?
- 验证表单输入内容是否为数字型?
必填(或必选)项目
下面的函数用来检查用户是否已填写表单中的必填(或必选)项目。假如必填或必选项为空,那么警告框会弹出,并且函数的返回值为 false,否则函数的返回值则为 true(意味着数据没有问题):
function validateForm() {
var x=document.forms["myForm"]["fname"].value;
if (x==null || x==""){
alert("First name must be filled out");
return false;
}
}
以上函数在 form 表单提交时被调用:
实例
<form name="myForm" action="demo_form.asp" onsubmit="return validateForm()" method="post">
First name: <input type="text" name="fname">
<input type="submit" value="Submit">
</form>
First name: <input type="text" name="fname">
<input type="submit" value="Submit">
</form>
E-mail 验证
下面的函数检查输入的数据是否符合电子邮件地址的基本语法。
意思就是说,输入的数据必须包含 @ 符号和点号(.)。同时,@ 不可以是邮件地址的首字符,并且 @ 之后需有至少一个点号:
function validateForm(){
var x=document.forms["myForm"]["email"].value;
var atpos=x.indexOf("@");
var dotpos=x.lastIndexOf(".");
if (atpos<1 || dotpos<atpos+2 || dotpos+2>=x.length){
alert("Not a valid e-mail address");
return false;
}
}
下面是连同 HTML 表单的完整代码:
实例
<form name="myForm" action="demo_form.asp" onsubmit="return validateForm();" method="post">
Email: <input type="text" name="email">
<input type="submit" value="Submit">
</form>
Email: <input type="text" name="email">
<input type="submit" value="Submit">
</form>
数字验证
下面的函数检查输入的数据是否是1~10之间的数字。假如输入的不为数字或不是,那么警告框会弹出,并且函数的返回值为 false,否则函数的返回值则为 true(意味着数据没有问题):
实例
<form name="myForm" action="demo_form.asp" onsubmit="return validateForm();" method="post">
<strong>请输入1到10之间的数字:</strong>
<input id="number">
<button type="button" onclick="myFunction()">提交</button>
</form>