创建方式:
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;