js中的正则表达式(部分)

正则表达式(常用正则校验、替换)
    引用数据类型,对象
       作用:
         1)表单的校验
         2)替换,替换某些敏感词汇
         3)提取,提取某段想要的字符串

   (1)创建
          1)字面量
                var rg=/hello/
          2)构造函数(RegExp)
              var rg2=new RegExp(/world/)

   (2)修饰符
            g     global      全局匹配
            i    ignore case     不区分大小写
            m     multiline     多行

   (3)正则表达式的使用
         1)test()   检测某个字符串是否匹配某个模式
            var result = pattern.test(str)
            参数:字符串
            返回值:布尔类型  true代表有符合条件的,false代表没有符合条件的
        
         2)exec()    检索字符串中的正则表达式的匹配
             var result = pattern.exec(str)  
                  参数:字符串
                  返回值:数组或者null
                       数组:匹配到的结果
         如果正则表达式中有修饰符“g”,这时,在pattern中会维护lastIndex属性,记录下一次开始的位置,当第二次执行exec的时候,从lastIndex开始检索。
         如果正则表达式中没有修饰符“g”,不会维护lastIndex属性,每次执行从开始位置检索

      字符类:
         [直接量]
            .     (点号,小数点) 匹配任意单个字符,但是行结束符除外
            \d     匹配任意阿拉伯数字。等价于[0-9]
            \D     匹配任意一个不是阿拉伯数字的字符。等价于[^0-9]。
            \w     匹配任意来自基本拉丁字母表中的字母数字字符,还包括下划线。等价于 [A-Za-z0-9_]
            \W       匹配任意不是基本拉丁字母表中单词(字母数字下划线)字符的字符。等价于 [^A-Za-z0-9_]
            \s     匹配一个空白符,包括空格、制表符、换页符、换行符和其他 Unicode 空格。
            \S     匹配一个非空白符。
            \t     匹配一个水平制表符(tab)
            \r     匹配一个回车符(carriage return)
            \n     匹配一个换行符(linefeed)
            \v     匹配一个垂直制表符(vertical tab)
            \f     匹配一个换页符(form-feed)

      字符集合:
          [xyz]     一个字符集合,也叫字符组。匹配集合中的任意一个字符。你可以使用连字符‘-’指定一个范围。[0-9]   [a-z]
          [^xyz] 一个反义或补充字符集,也叫反义字符组。也就是说,它匹配任意不在括号内的字符。你也可以通过使用连字符 '-' 指定一个范围内的字符。

      边界:
         ^    匹配输入开始。如果多行(multiline)标志被设为 true,该字符也会匹配一个断行(line break)符后的开始处。
         $     匹配输入结尾。如果多行(multiline)标志被设为 true,该字符也会匹配一个断行(line break)符的前的结尾处。
         \b      匹配一个零宽单词边界(zero-width word boundary),如一个字母与一个空格之间。
         \B     匹配一个零宽非单词边界(zero-width non-word boundary),如两个字母之间或两个空格之间。

      分组:
        (x)    匹配 x 并且捕获匹配项。 这被称为捕获括号(capturing parentheses)。
        \n    n 是一个正整数。一个反向引用(back reference),指向正则表达式中第 n 个括号(从左开始数)中匹配的子字符串。

      数量词:
        x*     匹配前面的模式 x 0 或多次。
        x+     匹配前面的模式 x 1 或多次。等价于 {1,}。
        x?     匹配前面的模式 x 0 或 1 次。
        x{n}     n 是一个正整数。前面的模式 x 连续出现 n 次时匹配
        x{n,}     n 是一个正整数。前面的模式 x 连续出现至少 n 次时匹配。
        x{n,m} n 和 m 为正整数。前面的模式 x 连续出现至少 n 次,至多 m 次时匹配。
        x*?     像上面的 * 一样匹配前面的模式 x,然而匹配是最小可能匹配。
        x+?     像上面的 + 一样匹配前面的模式 x,然而匹配是最小可能匹配。
        x|y     匹配 x 或 y

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值