正则表达式:语法:/expression/,斜杠表示起始位置
创建方式:
1、var regObj = new RegExp("pattern",[,"flags"]); pattern:必选项,正则表达式的字符串; flags:可选项,一些标志组合。
2、var regObj = /pattern/[flags];该方式不能用引号将pattern和flags括起来。
正则表示对象RegExp对象的方法:
exec:检索字符中是正则表示的匹配,返回找到的值,并确定其位置。 eg: var str = "abcdefg"; var reg = /cd/; var bol = reg.exec(str); //成功返回cd,失败返回null; test:检索字符串中指定的值,返回true或false。 eg: var bol = reg.test(str); //成功返回true,失败返回false;
string对象的方法:
match:找到一个或多个正则表示的匹配; search:检索与正则表达式相匹配的值; replace:替换与正则表达式匹配的字符串; split:把字符串分隔为字符串数字;//结果为一个数组;
RegExp对象的属性:
global:RegExp对象是否具有标志g;//全局查询,如果没有这个属性则在第一次
匹配之后就结束操作; ignorCase:RegExp对象是否具有标志i;//忽略大小写; multiline:RegExp对象是否具有标志m;//多行查询;
正则表达式的常用符号:
/.../:代表一个模式的开始和结束; ^:匹配字符串的开始; $:匹配字符串的结束; s:任何空白字符; S:任何非空白字符; d:匹配一个数字字符,等级[^0-9]; D:除了数字之外的任何字符,等价于[^0-9]; w:匹配一个数字,下划线或者字母字符,等价于[A-Za-z0-9]; W:任何非单字字符,等价于[^a-zA-Z0-9]; .:除了换行符之外的任何字符; {n}:匹配前一项n次; {n,}:匹配前一项n次,或者多次; {n,m}:匹配前一项至少n次,但是不能超过m次; *:匹配前一项0次或者多次,等价于{0,}; +:匹配前一项1次或者多次,等价于{1,}; ?:匹配前一项0次或者1次,等价于{0,1}; |:表示或者的意思;eg:[0-9]|[a-z]; ():用于分组;
eg:
全是字母: var reg = /^[a-zA-Z]+$/;至少有一个字母; 四个字母: var reg = /^[a-zA-Z]{4}$/;加上'^'避免了"3dedf"这类的也匹配上去; 11位qq号,第一位不能为0: /^[1-9]{1}d{10}$/ 18位身份证号: /^d{17}(d{1}|[a-zA-Z}{1})$/ 邮箱: /^w{2,}@w{2,}(.[a-zA-Z]{2,4}){1,2}$/;这样就可以匹配xx@yy.com.cn;