元字符( [ { \ ^ $ | ) ? * + .预定义的特殊字符字符 正则 描述\t /\t/ 制表符\n /\n/ 制表符\r /\r/ 回车符\f /\f/ 换页符\a /\a/ alert字符\e /\e/ escape字符\cX /\cX/ 与X相对应的控制字符\b /\b/ 与回退字符\v /\v/ 垂直制表符\0 /\0/ 空字符 字符 等同于 描述. [^\n\r] 除了换行和回车之外的任意字符\d [0-9] 数字字符\D [^0-9] 非数字字符\s [ \t\n\x0B\f\r] 空白字符\S [^ \t\n\x0B\f\r] 非空白字符\w [a-zA-Z_0-9] 单词字符(所有的字母)\W [^a-zA-Z_0-9] 非单词字符代码 类型 描述? 软性量词 出现零次或一次* 软性量词 出现零次或多次(任意次)+ 软性量词 出现一次或多次(至道一次){n} 硬性量词 对应零次或者n次{n,m} 软性量词 至少出现n次但不超过m次{n,} 软性量词 至少出现n次(+的升级版)贪婪量词,惰性量词与支配性量词贪婪量词,上面提到的所有简单量词。就像成语中说的巴蛇吞象那样,一口吞下整个字符串,发现吞不下(匹配不了),再从后面一点点吐出来(去掉最后一个字符,再看这时这个整个字符串是否匹配,不断这样重复直到长度为零)隋性量词,在简单量词后加问号。由于太懒了,先吃了前面第一个字符,如果不饱再捏起多添加一个(发现不匹配,就读下第二个,与最初的组成一个有两个字符串的字符串再尝试匹配,如果再不匹配,再吃一个组成拥有三个字符的字符串……)。其工作方式与贪婪量词相反。支配性量词,在简单量词后加加号。上面两种都有个不断尝试的过程,而支配性量词却只尝试一次,不合口味就算了。就像一个出身高贵居支配地位的公主。但你也可以说它是最懒量词。由于JavaScript不支持,所以它连出场的机会也没有了。var re1 = /.*bbb/g;//贪婪var re2 = /.*?bbb/g;//惰性// var re3 = /.*+bbb/g;//支配性,javascript不支持,IE与所有最新的标准浏览器都报错alert(re1.test("abbbaabbbaaabbbb1234")+"");//truealert(re1.exec("abbbaabbbaaabbbb1234")+"");//nullalert("abbbaabbbaaabbbb1234".match(re1)+"");//abbbaabbbaaabbbbalert(re2.test("abbbaabbbaaabbbb1234")+"");//truealert(re2.exec("abbbaabbbaaabbbb1234")+"");//aabbbalert("abbbaabbbaaabbbb1234".match(re2)+"");//abbb,aabbb,aaabbb分组到目前为止,我们只能一个字符到匹配,虽然量词的出现,能帮助我们处理一排密紧密相连的同类型字符。但这是不够的,下面该轮到小括号出场了,中括号表示范围内选择,大括号表示重复次数。小括号允许我们重复多个字符。//分组+量词alert(/(dog){2}/.test("dogdog"))//true//分组+范围alert("baddad".match(/([bd]ad?)*/))//baddad,dad//分组+分组alert("mon and dad".match(/(mon( and dad)?)/))//mon and dad,mon and dad, and dad反向引用反向引用标识由正则表达式中的匹配组捕获的子字符串。每个反向引用都由一个编号或名称来标识,并通过“\编号”表示法进行引用。var color = "#990000";/#(\d+)/.test(color);alert(RegExp.$1);//990000alert(/(dog)\1/.test("dogdog"))//truevar num = "1234 5678";var newNum = num.replace(/(\d{4}) (\d{4})/,"$2 $1");alert(newNum)候选继续在分组上做文章。在分组中插入管道符(“|”),把它划分为两个或多个候多项。var reg = /(red|black|yellow)!!/;alert(reg.test("red!!"))//truealert(reg.test("black!!"))//truealert(reg.test("yellow!!"))//true非捕获性分组并不是所有分组都能创建反向引用,有一种特别的分组称之为非捕获性分组,它是不会创建反向引用。反之,就是捕获性分组。要创建一个非捕获性分组,只要在分组的左括号的后面紧跟一个问号与冒号就行了。var color = "#990000";/#(?:\d+)/.test(color);alert(RegExp.$1);//""题目,移除所有标签,只留下innerText!var html = "Ruby Louvreby 司徒正美
";var text = html.replace(/<(?:.|\s)*?>/g, "");alert(text)注意:javascript不存在命名分组前瞻继续在分组内做文章。前瞻与后瞻其实都属于零宽断言,但javascript不支持后瞻。零宽断言正则 名称 描述(?=exp) 正向前瞻 匹配exp前面的位置(?!exp) 负向前瞻 匹配后面不是exp的位置(?<=exp) 正向后瞻 匹配exp后面的位置不支持(? Ruby Louvreby 司徒正美
";var text = html.replace(/<(?!hr)(?:.|\s)*?>/ig,"")alert(text)//Ruby Louvre
by 司徒正美边界一个要与字符类合用的东西。边界正则 名称 描述^ 开头 注意不能紧跟于左中括号的后面$ 结尾 \b 单词边界 指[a-zA-Z_0-9]之外的字符\B 非单词边界 题目,设计一个字符串原型方法,实现首字母大写!var a = "ruby";String.prototype.capitalize = function () {return this.replace(/^\w/, function (s) {return s.toUpperCase();});}alert(a.capitalize())//Ruby单词边界举例。要匹配的东西的前端或未端不能为英文字母阿拉伯字数字或下横线。var str = "12w-eefd&efrew";alert(str.match(/\b\w+\b/g))//12w,eefd,efrew实例属性 描述global 是当前表达式模式首次匹配内容的开始位置,从0开始计数。其初始值为-1,每次成功匹配时,index属性都会随之改变。ignoreCase 返回创建RegExp对象实例时指定的ignoreCase标志(i)的状态。如果创建RegExp对象实例时设置了i标志,该属性返回True,否则返回False,默认值为False。lastIndex 是当前表达式模式首次匹配内容中最后一个字符的下一个位置,从0开始计数,常被作为继续搜索时的起始位置,初始值为-1, 表示从起始位置开始搜索,每次成功匹配时,lastIndex属性值都会随之改变。(只有使用exec()或test()方法才会填入,否则为0)multiLine 返回创建RegExp对象实例时指定的multiLine标志(m)的状态。如果创建RegExp对象实例时设置了m标志,该属性返回True,否则返回False,默认值为False。source 返回创建RegExp对象实例时指定的表达式文本字符串。var str = "JS's Louvre";var reg = /\w/g;alert(reg.exec(str));//Jalert(reg.lastIndex);//1alert(reg.exec(str));//Salert(reg.lastIndex);//2alert(reg.exec(str));//salert(reg.lastIndex);//4alert(reg.exec(str));//Lalert(reg.lastIndex);//6//原文来自:http://blog.csdn.net/nebula1982/article/details/6659702