专注收集记录技术开发学习笔记、技术难点、解决方案
网站信息搜索 >> 请输入关键词:
您当前的位置: 首页 > JavaScript

关于JS中的惯用表单验证+正则表达式

发布时间:2010-05-20 14:01:29 文章来源:www.iduyao.cn 采编人员:星星草
关于JS中的常用表单验证+正则表达式

一、非空验证

    trim:去空格(去掉前后的空格),任何字符串都可以用这个方法。写法为:if(v.trim().length==0),表示如果去掉空格后的字符串的长度为0。

<body>
<form action="Untitled-1.html" method="post">
<input type="text" name="uid" id="uid"  onblur="Check()" />//文本框,用户输入内容。onblur是鼠标失去焦点时触发。
<input type="submit" value="确定" id="btn" onclick="return Check()" />//提交按钮,点击事件执行的内容根据return的值判断。
</form>
</body>
<script type="text/javascript">
function Check()
{
  var v = document.getElementById("uid").value;//取到用户输入的值
  if(v.trim().length==0)//对去掉空格后的值进行验证
  {
  alert("用户名不能为空");//输入值为空
    return false;//返回false
  }
  else//输入值不为空
  {
    return true;//返回true
  }
}
</script>

二、对比验证

<input type="text" name="pw1" id="pw1" />//两个文本框
<input type="text" name="pw2" id="pw2" />
<input type="submit" value="确定" id="btn" onclick="return Check()" />//提交按钮

</form>
</body>
<script type="text/javascript">
function Check()
{
  var v1 = document.getElementById("pw1").value;//第一个文本框的值
  var v2 = document.getElementById("pw2").value;//第二个文本框的值
  if(v1==v2)//如果两个文本框的值一样
  {
    return true;//返回true
  }
  else//如果两个文本框的值不一样
  {
    alert("两次输入的密码不相同");//输出"两次输入的密码不相同"
    return false;//返回false
  }
}

三、范围验证

<input type="text" name="age" id="age" />//输入年龄的文本框
<input type="submit" value="确定" id="btn" onclick="return Check()" />//提交按钮
</form>
</body>
<script type="text/javascript">

function Check()
{
  var v = parseInt(document.getElementById("age").value);//取年龄值
  if(v>=18 && v<=50) //如果年龄在范围内
  {
    return true;//返回true
  }
  else//如果不在范围内
  {
    alert("输入的年龄不在单位内");//输出"输入的年龄不在单位内"
  return false;//返回false
  }
}

四、js获取网页面的高度和宽度

网页可见区域宽:document.body.clientWidth
网页可见区域高:document.body.clientHeight
网页可见区域宽:document.body.offsetWidth(包括边线的宽)
网页可见区域高:document.body.offsetHeight(包括边线的宽)
网页正文全文宽:document.body.scrollWidth
网页正文全文高:document.body.scrollHeight
网页被卷去的高:document.body.scrollTop(IE7无效)
网页被卷去的左:document.body.scrollLeft(IE7无效)

网页被卷去的高:document.documentElement.scrollTop(IE7有效)

网页被卷去的左:document.documentElement.scrollLeft(IE7有效)
网页正文部分上:window.screenTop
网页正文部分左:window.screenLeft
屏幕分辨率的高:window.screen.height
屏幕分辨率的宽:window.screen.width
屏幕可用工作区高度:window.screen.availHeight
屏幕可用工作区宽度:window.screen.availWidth

相对于窗口左上角的X:window.event.clientX

相对于窗口左上角的Y:window.event.clientY
相对于整个页面的X:window.event.X
相对于整个页面的Y:window.event.Y

五、固定格式验证(正则验证)

    固定格式验证是指对输入的内容是否符合格式要求的验证,写法为if(v.match()),natch里面放正则表达式,如果匹配成功,return的是输入的内容,如果匹配失败,return的是null。正则表达式是对输入的内容的格式的要求,比如邮箱地址、电话号码、身份证号码等。常用的正则表达式符号有:

//:正则表达式的书写规则,//中间写正则表达式的内容,/内容/;

^:匹配开头,/^ve表示以ve开头;

$:匹配结尾,ve$/表示以ve结束;

d:一个任意的数字,等于0-9;

m:一个任意的数字或者字母,包括下划线;

s:任意的不可见的字符串,例如空格、换行;

S:任意的可见的字符;

{n}:前面的表达式重复n变,n等于几就是几遍;

{m,n}:把前面的表达式重复至少m遍,最多n遍;
{m, }:把前面的表达式重复至少m遍,最多不限;

+:左边的表达式,至少出现1次,至多不限,相当于{1, };

*:左边的表达式,至少出现0次,至多不限,相当于{0, };

?:左边的表达式,至少出现0次,最多出现1次,相当于{0,1};

[a,b,c]:只能取方括号中内容之一;

[a-z]或[1-9]:在a-z或者0-9取值;

r:表示换行;

n:表示换行;

t:表示Tab键;

:表示;

":"

x|y:可以匹配x或者y;

[^xyz]:不匹配[]里面的内容;

 

常用的正则表达式:  

  • Email地址:^w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$
  • 域名:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?
  • InternetURL:[a-zA-z]+://[^s]* 或 ^http://([w-]+.)+[w-]+(/[w-./?%&=]*)?$
  • 手机号码:^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])d{8}$
  • 电话号码(“XXX-XXXXXXX”、”XXXX-XXXXXXXX”、”XXX-XXXXXXX”、”XXX-XXXXXXXX”、”XXXXXXX”和”XXXXXXXX):^($$d{3,4}-)|d{3.4}-)?d{7,8}$
  • 国内电话号码(0511-4405222、021-87888822):d{3}-d{8}|d{4}-d{7}
  • 身份证号(18位数字):/^[1-9]d{5}[1-9]d{3}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])d{3}([0-9]|X)$/
  • 身份证号(15位数字):/^[1-9]d{7}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])d{3}$/
  • 短身份证号码(数字、字母x结尾):^([0-9]){7,18}(x|X)?$ 或 ^d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$
  • 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
  • 密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线):^[a-zA-Z]w{5,17}$
  • 强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间):^(?=.*d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$
  • 日期格式:^d{4}-d{1,2}-d{1,2}
  • 一年的12个月(01~09和1~12):^(0?[1-9]|1[0-2])$
  • 一个月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$
  • 钱的输入格式:
    • 有四种钱的表示形式我们可以接受:”10000.00″ 和 “10,000.00”, 和没有 “分” 的 “10000” 和 “10,000”:^[1-9][0-9]*$
    • 这表示任意一个不以0开头的数字,但是,这也意味着一个字符”0″不通过,所以我们采用下面的形式:^(0|[1-9][0-9]*)$
    • 一个0或者一个不以0开头的数字.我们还可以允许开头有一个负号:^(0|-?[1-9][0-9]*)$
    • 这表示一个0或者一个可能为负的开头不为0的数字.让用户以0开头好了.把负号的也去掉,因为钱总不能是负的吧.下面我们要加的是说明可能的小数部分:^[0-9]+(.[0-9]+)?$
    • 必须说明的是,小数点后面至少应该有1位数,所以”10.”是不通过的,但是 “10” 和 “10.2” 是通过的:^[0-9]+(.[0-9]{2})?$
    • 这样我们规定小数点后面必须有两位,如果你认为太苛刻了,可以这样:^[0-9]+(.[0-9]{1,2})?$
    • 这样就允许用户只写一位小数。下面我们该考虑数字中的逗号了,我们可以这样:^[0-9]{1,3}(,[0-9]{3})*(.[0-9]{1,2})?$
    • 1到3个数字,后面跟着任意个 逗号+3个数字,逗号成为可选,而不是必须:^([0-9]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$
    • 备注:这就是最终结果了,别忘了”+”可以用”*”替代。如果你觉得空字符串也可以接受的话(奇怪,为什么?)最后,别忘了在用函数时去掉去掉那个反斜杠,一般的错误都在这里
  • xml文件:^([a-zA-Z]+-?)+[a-zA-Z0-9]+.[x|X][m|M][l|L]$
  • 中文字符的正则表达式:[u4e00-u9fa5]
  • 双字节字符:[^x00-xff] (包括汉字在内,可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1))
  • 空白行的正则表达式:ns*r (可以用来删除空白行)
  • HTML标记的正则表达式:<(S*?)[^>]*>.*?</1>|<.*? /> (网上流传的版本太糟糕,上面这个也仅仅能部分,对于复杂的嵌套标记依旧无能为力)
  • 首尾空白字符的正则表达式:^s*|s*$或(^s*)|(s*$) (可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式)
  • 腾讯QQ号:[1-9][0-9]{4,} (腾讯QQ号从10000开始)
  • 中国邮政编码:[1-9]d{5}(?!d) (中国邮政编码为6位数字)
  • IP地址:d+.d+.d+.d+ (提取IP地址时有用)
  • IP地址:((?:(?:25[0-5]|2[0-4]d|[01]?d?d).){3}(?:25[0-5]|2[0-4]d|[01]?d?
友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。

其他相似内容:

热门推荐: