您的位置:首页 > 编程语言

一个很流行的表单验证代码

2013-10-30 14:03 489 查看
////////////////////////////////////////////////////////////////////////////////

////////////////////////////////////////////////////////////////////////////////

//主函数

function CheckForm(oForm)

{

var els = oForm.elements;

//遍历所有表元素

for(var i=0;i<els.length;i )

{

//是否需要验证

if(els[i].check)

{

//取得验证的正则字符串

var sReg = els[i].check;

//取得表单的值,用通用取值函数

var sVal = GetValue(els[i]);

//字符串->正则表达式,不区分大小写

var reg = new RegExp(sReg,"i");

if(!reg.test(sVal))

{

//验证不通过,弹出提示warning

alert(els[i].warning);

//该表单元素取得焦点,用通用返回函数

GoBack(els[i])

return false;

}

}

}

}

//通用取值函数分三类进行取值

//文本输入框,直接取值el.value

//单多选,遍历所有选项取得被选中的个数返回结果"00"表示选中两个

//单多下拉菜单,遍历所有选项取得被选中的个数返回结果"0"表示选中一个

function GetValue(el)

{

//取得表单元素的类型

var sType = el.type;

switch(sType)

{

case "text":

case "hidden":

case "password":

case "file":

case "textarea": return el.value;

case "checkbox":

case "radio": return GetValueChoose(el);

case "select-one":

case "select-multiple": return GetValueSel(el);

}

//取得radio,checkbox的选中数,用"0"来表示选中的个数,我们写正则的时候就可以通过0{1,}来表示选中个数

function GetValueChoose(el)

{

var sValue = "";

//取得第一个元素的name,搜索这个元素组

var tmpels = document.getElementsByName(el.name);

for(var i=0;i<tmpels.length;i )

{

if(tmpels[i].checked)

{

sValue = "0";

}

}

return sValue;

}

//取得select的选中数,用"0"来表示选中的个数,我们写正则的时候就可以通过0{1,}来表示选中个数

function GetValueSel(el)

{

var sValue = "";

for(var i=0;i<el.options.length;i )

{

//单选下拉框提示选项设置为value=""

if(el.options[i].selected &&
el.options[i].value!="")

{

sValue = "0";

}

}

return sValue;

}

}

//通用返回函数,验证没通过返回的效果.分三类进行取值

//文本输入框,光标定位在文本输入框的末尾

//单多选,第一选项取得焦点

//单多下拉菜单,取得焦点

function GoBack(el)

{

//取得表单元素的类型

var sType = el.type;

switch(sType)

{

case "text":

case "hidden":

case "password":

case "file":

case "textarea": el.focus();var rng = el.createTextRange();
rng.collapse(false); rng.select();

case "checkbox":

case "radio": var els =
document.getElementsByName(el.name);els[0].focus();

case "select-one":

case "select-multiple":el.focus();

}

}

//check field

function CheckField(Field)

{

//是否需要验证

if(Field.check)

{

//取得验证的正则字符串

var sReg = Field.check;

//取得表单的值,用通用取值函数

var sVal = GetValue(Field);

//字符串->正则表达式,不区分大小写

var reg = new RegExp(sReg);

if(!reg.test(sVal))

{

//验证不通过,弹出提示warning

alert(Field.warning);

//该表单元素取得焦点,用通用返回函数

GoBack(Field)

return false;

}

}

return true;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: