美文网首页
Js正则表达式

Js正则表达式

作者: 前端小菜_蓝草 | 来源:发表于2018-01-03 14:50 被阅读0次
    正则表达式是描述字符模式的对象,用于对字符串模式匹配及检索替换,是对字符串执行模式匹配的强大工具,应用比较广泛,一般普通小型公司,用到的正则大都是一些金额数字、邮箱地址等表单验证,而这些一般人使用时,都是百度谷歌搜索,然后复制黏贴,导致对正则越来越没有清晰的认识。个人感觉自己就是如此,因此花点时间从简入繁一点点记录写正则的过程,希望加深自己的理解。
    1、正则表达式的修饰符就3个:
            i(不区分大小写);
            g(执行全局匹配);
            m(执行多行匹配);
    2、表达式的模式:
          2.1、表达式:
              2.1.1、[abc] 查找括号内的任何字符;
              2.1.2、[^abc] 查找任何不在括号内的字符;
              2.1.3、[0-9]查找0~9的数字;//英文字符也是类似。
              2.1.4、(x|y)查找x或者y的内容;
          2.2、元字符:
                2.2.1、\d 查找数字;
                2.2.2、\D 查找非数字字符;
                2.2.3、\s 查找空白字符;
                2.2.4、\S 查找非空白字符;
                2.2.5、\w 查找单词字符;
                2.2.6、\W 查找非单词字符;
                2.2.7、\b 匹配单词边界;
                2.2.8、\B 匹配非单词边界;
                2.2.9、\0 匹配NULL字符;
                2.2.10、\n 匹配换行符,\f 查找换页符,\r查找回车符;
                2.2.11、\t 查找制表符,\v 查找垂直制表符;
                2.2.12、\xxx查找以八进制数xxx规定的字符;
                2.2.13、\xdd 查找以16进制dd规定的字符;
                2.2.14、\uxxxx 查找以16进制数xxxx规定的Unicode字符;
                2.2.15、. 查找单个字符,除了换行和行结束符;
          2.3、量词:
                2.3.1、n+ 匹配任何包含一个n的字符串;
                2.3.2、n* 匹配任何包含0个或多个n的字符串;
                2.3.3、n? 匹配任何包含0个或1个n的字符串;
                2.3.4、n{x} 匹配包含x个n的字符串,个数不对也是无法匹配的;
                2.3.5、n{x.} x是正整数,前面出现n个x后,才开始输出匹配的;
                2.3.6、n{x,y},x次之后开始匹配,但最多y次;
                2.3.7、n$ 匹配任何结尾为n的字符串;
                2.3.8、^n 匹配任何开头为n的字符串;
                2.3.9、?=n 匹配任何其后紧接指定字符串n的字符串;
                2.3.10、?!n 匹配任何其后没有紧接指定字符串n的字符串;
        2.4、RegExp 对象方法:
                2.4.1、compile 修改编译正则表达式;
                2.4.2、exec 检索字符串中指定的值,返回找到的值,并确认其位置;
                2.4.3、test 检索字符串指定的值,返回true或false;这个用得最多!
    

    Code篇:

    1、简单的字符串操作:
        //字符串查询方法:
        var str = "hello Word";
        var n = str.search(/word/i);
        //replace()替换
        var restr = "hello lanbinghan";
        var txt = restr.replace("hello", "hi");
    2、验证数字
          /^[0-9]{0,1}$/;   //只验证个位数,后面{}区间是用来控制整数的位数的;
          /^\-[0-9]{0,1}$/;  //验证负的个位整数;
          /^\+?[1-9][0-9]*$/;  //验证非0正整数
          /^[0-9]+(.[0-9]{2})?$/;//有2位小数的正实数    
    3、验证英文字符
          /^[A-Za-z]+$/  //验证大小写英文字母;
          /^[A-Za-z0-9]+$/ //验证数字和英文的组合;
          /^\w+$/ //验证由数字、英文字符或者下划线组成的字符串;
          /^[a-zA-Z]\w{5,17}$/  //验证用户密码
    4、常用验证
          /^([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+\.[a-zA-Z]{2,3}$/  //验证email地址
          /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/ //验证身份证
          /^1[34578]\d{9}$/ //验证手机号
          /^(([0\+]\d{2,3}-)?(0\d{2,3})-)(\d{7,8})(-(\d{3,}))?$/  //验证座机电话
          /^[\u4e00-\u9fa5],{0,}$/ //验证汉字
    

    写正则,开始将逻辑理清楚,然后拿这些表达式等基础元素一点点按照逻辑拼接起来。

    相关文章

      网友评论

          本文标题:Js正则表达式

          本文链接:https://www.haomeiwen.com/subject/vzhqnxtx.html