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

点赞(0)

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部