正则表达式:语法:/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;