javaScript RegExp对象:html
global——Boolean值、表示g(全局选项)是否已设置
ignoreCase——Boolean值、表示i(忽略大小写选项)是否已设置
lastIndex——整数、表明下次匹配将会从哪一个字符位置开始(只有当使用exec()或test()函数才会填入、不然为0)
multiline——Boolean值、表示m(多行模式选项)是否已设置
source——正则表达式的源字符串形式。例如、表达式/[ba]*/的source将返回"[ba]*"。
通常不会使用global、ignoreCase、multiline和source属性、由于通常以前就已知道了这些数据。
真正有用的属性是lastIndex、它能够告诉你正则表达式在某个字符串中中止以前、查找了多远。java
- var sToMatch = "bbq is short for barbecue";
- var reB = /b/g;
- reB.exec(sToMatch);
- alert(reB.lastIndex); //out: 1
- reB.exec(sToMatch);
- alert(reB.lastIndex); //out: 2
- reB.exec(sToMatch);
- alert(reB.lastIndex); //out: 18
- reB.exec(sToMatch);
- alert(reB.lastIndex); //out: 21
正则表达式reB查找的是b。当它首次检测sToMatch时、
它发如今第一个位置——也就是位置0——是b;
所以、lastIndex属性就被设置成一、
而再次调用exec()时就从这个地方开始执行。
再次调用exec()、表达式在位置1又发现了b、
因而将lastIndex设值为2.第三次调用时、发现b在位置1七、
因而又将lastIndex设值为1八、如此继续。
若是想从头开始匹配、则能够将lastIndex设为0。正则表达式
静态属性:ide
- /**
- * 它们都有两个名字:一个复杂名字和一个以美圆符号开头的简短名字。
- * 长名 短名 描述
- * input $_ 最后用于匹配的字符串(传递给exec()或test()的字符串)
- * lastMatch $& 最后匹配的字符
- * lastParen $+ 最后匹配的分组
- * leftContext $` 在上次匹配的前面的子串
- * multiline $* 用于指定是否全部表达式都使用多行模式的布尔值
- * rightContext $' 在上次匹配以后的子串
- */
- var sToMatch = "古道西风瘦马、夕阳西下、断肠人在天涯!";
- var reB = /(西)风/g;
- reB.test(sToMatch);
- alert(RegExp.$_); //out:古道西风瘦马、夕阳西下、断肠人在天涯!
- alert(RegExp.leftContext); //out:古道
- /*
- * 使用短名时有些字符是不合法的须要使用[]
- * ["$'"]
- * ["$+"]
- * ["$&"]
- * ["$`"]
- */
- alert(RegExp["$'"]); //out:瘦马、夕阳西下、断肠人在天涯!
经常使用正则验证——原连接 http://topic.csdn.net/u/20080820/14/dadb903c-8724-422e-a3bd-f2f1c4e812c6.html函数
- ^\d+$ //匹配非负整数(正整数 + 0)
- ^[0-9]*[1-9][0-9]*$ //匹配正整数
- ^((-\d+)|(0+))$ //匹配非正整数(负整数 + 0)
- ^-[0-9]*[1-9][0-9]*$ //匹配负整数
- ^-?\d+$ //匹配整数
- ^\d+(\.\d+)?$ //匹配非负浮点数(正浮点数 + 0)
- ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$ //匹配正浮点数
- ^((-\d+(\.\d+)?)|(0+(\.0+)?))$ //匹配非正浮点数(负浮点数 + 0)
- ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$ //匹配负浮点数
- ^(-?\d+)(\.\d+)?$ //匹配浮点数
- ^[A-Za-z]+$ //匹配由26个英文字母组成的字符串
- ^[A-Z]+$ //匹配由26个英文字母的大写组成的字符串
- ^[a-z]+$ //匹配由26个英文字母的小写组成的字符串
- ^[A-Za-z0-9]+$ //匹配由数字和26个英文字母组成的字符串
- ^\w+$ //匹配由数字、26个英文字母或者下划线组成的字符串
- ^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$ //匹配email地址
- ^[a-zA-z]+://匹配(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$ //匹配url
- 匹配中文字符的正则表达式: [\u4e00-\u9fa5]
- 匹配双字节字符(包括汉字在内):[^\x00-\xff]
- 应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
- String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}
- 匹配空行的正则表达式:\n[\s| ]*\r
- 匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/
- 匹配首尾空格的正则表达式:(^\s*)|(\s*$)
/* 正则表达式用例- * 一、^\S+[a-z A-Z]$ 不能为空 不能有空格 只能是英文字母
- * 二、\S{6,} 不能为空 六位以上
- * 三、^\d+$ 不能有空格 不能非数字
- * 四、(.*)(\.jpg|\.bmp)$ 只能是jpg和bmp格式
- * 五、^\d{4}\-\d{1,2}-\d{1,2}$ 只能是2004-10-22格式
- * 六、^0$ 至少选一项
- * 七、^0{2,}$ 至少选两项
- * 八、^[\s|\S]{20,}$ 不能为空 二十字以上
- * 九、^\+?[a-z0-9](([-+.]|[_]+)?[a-z0-9]+)*@([a-z0-9]+(\.|\-))+[a-z]{2,6}$邮件
- * 十、\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*([,;]\s*\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*)* 输入多个地址用逗号或空格分隔邮件
- * 十一、^(\([0-9]+\))?[0-9]{7,8}$电话号码7位或8位或前面有区号例如(022)87341628
- * 十二、^[a-z A-Z 0-9 _]+@[a-z A-Z 0-9 _]+(\.[a-z A-Z 0-9 _]+)+(\,[a-z A-Z 0-9 _]+@[a-z A-Z 0-9 _]+(\.[a-z A-Z 0-9 _]+)+)*$
- * 只能是字母、数字、下划线;必须有@和.同时格式要规范 邮件
- * 13 ^\w+@\w+(\.\w+)+(\,\w+@\w+(\.\w+)+)*$上面表达式也能够写成这样子,更精练。
- 14 ^\w+((-\w+)|(\.\w+))*\@\w+((\.|-)\w+)*\.\w+$
补充:this
- 21。匹配空行的正则表达式:\n[\s| ]*\r
- 21。匹配空行的正则表达式:/^\s*$/m
- 22。匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*)\/>/
- 22。匹配HTML标记的正则表达式:/<([^>]+)>[^<>]*<\/\1>|<([^>]+)\/>/
- 这个实际上做用不大,由于正则表达式不能支持嵌套匹配,仅 .NET 的表达式引擎有这个功能。
- 23。匹配首尾空格的正则表达式:(^\s*)|(\s*$)
- 23。匹配首尾空格的正则表达式:^\s+|\s+$
- 为 JavaScript 的 String 增长 trim() 函数:
- String.prototype.trim = function() {
- return this.replace(/^\s+/, '').replace(/\s+$/, '');
- }
- * 四、(.*)(\.jpg|\.bmp)$ 只能是jpg和bmp格式
- * 四、([^.]+)\.(jpg|bmp) 只能是jpg和bmp格式
- * 八、^[\s|\S]{20,}$ 不能为空 二十字以上
- * 八、^\S{20,}$ 不能为空 二十字以上