【实用】常用JS验证函数大全
[code language=js]/**********************************************************************
* 常用JS验证函数
* QQ:12165743
* Email:wqb7156@163.com
* Date:2007-06-06
**********************************************************************
使用说明:正确匹配返回true,否则返回false
----------------------------------------------------------------------
函数列表:
CheckInput() 控件验证
IsLen() 判断长度
IsUsername() 验证用户名
IsPassword() 验证密码
IsEn() 验证是否为字母
IsCn() 验证是否为汉字
IsEmail() 验证E-mail
IsMSN() 验证MSN
IsQQ() 验证QQ号
IsHttpUrl() 验证网址
IsDoMainName() 验证域名
IsIpv4() 验证IPV4地址
IsImgURL() 验证图片地址
IsCellPhone() 验证手机号码
IsPhone() 验证固定电话
IsZipCode() 验证邮编
IsIdCard() 验证身份证号码
IsDateFormat() 验证日期格式YY-MM-DD
IsRangeTime() 验证时间格式HH:MM:SS
IsMoney() 验证金额格式
IsInt() 验证数字,并判断其范围
IsSearch() 验证关键字
-----------------------------------------------------------------------
使用例子:
<script language="javascript">
var email="username";
alert(email.IsEmail());
</script>
<input name="email" type="text" id="email" value="wqb7156#163.com" />
<div id="Megdiv"></div>
<script language="javascript">
if(!CheckInput("email","email","邮箱","notnull",'IsEmail',0,0,"Megdiv")) return flase;
</script>
----------------------------------------------------------------------*/
//控件验证 CheckInput(Id,Name,Title,Null,Format, LengthMin, LengthMax,Megdiv)
function CheckInput()
{
var Id=arguments[0];
var Name=arguments[1];
var Title=arguments[2];
var Null=arguments[3].toLowerCase();
var Format=arguments[4]
var LengthMin=arguments[5]
var LengthMax=arguments[6];
var Megdiv=(arguments[7]==null)?Id+'_meg':arguments[7];
var obj=document.getElementById(Id);
var Name=document.getElementsByName(Name);
var value=obj.value.replace(/(^\s*)|(\s*$)/g, "");
var type=obj.type.toLowerCase();
var showdiv=document.getElementById(Megdiv);
//是否为空,如不为空判断长度范围
if(Null=='notnull')
{
switch(type){
//文件域
case"file":
if( value=='' )
{
showdiv.innerHTML='×请选择你要上传的图片';
obj.focus();
return false;
}
//文本框
case"text":
if( value=='' )
{
showdiv.innerHTML='×'+Title+'不能为空';
obj.focus();
return false;
}
break;
//文本域
case"textarea":
if( value=='' )
{
showdiv.innerHTML='×'+Title+'不能为空';
obj.focus();
return false;
}
break;
//密码框
case"password":
if( value=='' )
{
showdiv.innerHTML='×'+Title+'不能为空';
obj.focus();
return false;
}
//确认密码
if(Id.substr(Id.length-2,2)=='re')
{
var pwd=Id.substr(0,Id.length-3);
if(document.getElementById(pwd).value!=value)
{
showdiv.innerHTML='×'+'两次输入的密码不相同';
obj.focus();
return false;
}
}
break;
//单选按钮
case"radio":
var flag=false;
for (var i=0;i<Name.length;i++)
{
if(Name.checked) flag=true;
//break;
}
if(!flag)
{
showdiv.innerHTML='×'+Title+'不能为空';
return false;
}
break;
//复选框
case"checkbox":
var flag=false;
for (var i=0;i<Name.length;i++)
{
if(Name.checked) flag=true;
//break;
}
if(!flag)
{
showdiv.innerHTML='×'+Title+'不能为空';
return false;
}
break;
//列表框
case"select-one":
if(obj.selectedIndex==0)
{
showdiv.innerHTML='×'+Title+'不能为空';
obj.focus();
return false;
}
break;
}
}else
{
//确认密码
if(type=='password'&&Id.substr(Id.length-2,2)=='re')
{
var pwd=Id.substr(0,Id.length-3);
if(document.getElementById(pwd).value!=value)
{
showdiv.innerHTML='×'+'两次输入的密码不相同';
obj.focus();
return false;
}
}
}
//长度判断
if(value!=''&&!value.IsLen(LengthMin,LengthMax))
{
showdiv.innerHTML='×'+Title+'长度必须在'+LengthMin+'和'+LengthMax+'之间';
obj.focus();
return false;
}
//验证数据格式
if(Format!='nocheck'&&value!='')
{
//选择函数
switch(Format)
{
case "IsLen": Format=value.IsLen(); break;
case "IsUsername": Format=value.IsUsername(); break;
case "IsPassword": Format=value.IsPassword(); break;
case "IsEn": Format=value.IsEn(); break;
case "IsCn": Format=value.IsCn(); break;
case "IsEmail": Format=value.IsEmail(); break;
case "IsMSN": Format=value.IsMSN(); break;
case "IsQQ": Format=value.IsQQ(); break;
case "IsHttpUrl": Format=value.IsHttpUrl(); break;
case "IsDoMainName": Format=value.IsDoMainName(); break;
case "IsIpv4": Format=value.IsIpv4(); break;
case "IsImgURL": Format=value.IsImgURL(); break;
case "IsCellPhone": Format=value.IsCellPhone(); break;
case "IsPhone": Format=value.IsPhone(); break;
case "IsZipCode": Format=value.IsZipCode(); break;
case "IsIdCard": Format=value.IsIdCard(); break;
case "IsDateFormat": Format=value.IsDateFormat(); break;
case "IsRangeTime": Format=value.IsRangeTime(); break;
case "IsMoney": Format=value.IsMoney(); break;
case "IsInt": Format=value.IsInt(); break;
case "IsSearch": Format=value.IsSearch(); break;
}
if(!Format)
{
showdiv.innerHTML='×'+Title+'格式不正确';
obj.focus();
return false;
}
}
showdiv.innerHTML="√";
return true;
}
//判断长度(长度不限为0)
String.prototype.IsLen = function()
{
var isRightFormat=false;
var minnum=arguments[0]?arguments[0]:0;
var maxnum=arguments[1]?arguments[1]:0;
isRightFormat = (minnum == 0 && maxnum ==0 ? true : (calculate_byte(this) >= minnum && calculate_byte(this) <= maxnum ? true : false));
return isRightFormat;
}
//验证用户名
String.prototype.IsUsername = function()
{
var myReg = /^[0-9a-zA-Z\-]+$/;
if(myReg.test(this)) return true;
return false;
}
//验证密码
String.prototype.IsPassword = function()
{
var myReg = /^[0-9a-zA-Z]+$/;
if(myReg.test(this)) return true;
return false;
}
//验证是否为字母
String.prototype.IsEn = function()
{
var myReg = /^[a-zA-Z]+$/;
if(myReg.test(this)) return true;
return false;
}
//验证是否为汉字
String.prototype.IsCn = function()
{
var myReg =/^[\u0391-\uFFE5]+$/;
if(myReg.test(this)) return true;
return false;
}
//验证E-ma
补充:web前端 , JavaScript ,