正则表达式的元字符是包含特殊含义的字符,它们有一些特殊的功能,可以控制匹配模式的方式,反斜杠后的元字符失去其特殊含义。

  • 单个字符和数字

    • .表示匹配除换行符外的单个字符,两个.就表示匹配两个字符

       var pattern1=/g.gle/;
      alert(pattern1.test('gogle'))//true
      alert(pattern1.test('g\ngle'))//换行符false
      alert(pattern1.test('ggle'))//没有匹配false
      var pattern2=/g..gle/;
      alert(pattern2.test('google'))//true
      alert(pattern2.test('gooogle'))//false
    • [a-z0-9A-Z]
      • [a-z] 表示26个小写字母任意一个都匹配

         var pattern1=/[a-z]oogle/;
        alert(pattern1.test('hoogle'))//true
        alert(pattern1.test('google'))//true
      • [A-Z] 表示26个大写字母任意一个都匹配
         var pattern1=/[A-Z]oogle/;
        alert(pattern1.test('Aoogle'))//true
        alert(pattern1.test('google'))//false
      • [0-9] 表示0-9任意一个数字都匹配
          var pattern1=/[0-9]oogle/;
        alert(pattern1.test('000000oogle'))//true
        alert(pattern1.test('google'))//flase
      • [a-zA-Z0-9] 表示匹配任意字母与数字
           var pattern1=/[a-zA-Z0-9]oogle/;
        alert(pattern1.test('0oogle'))//true
        alert(pattern1.test('google'))//true
        alert(pattern1.test('Foogle'))//true

        【结合重复字符使用】表示可以匹配任意多个字符

               var pattern1=/[0-9]*oogle/;
        alert(pattern1.test('oogle'))//true
        alert(pattern1.test('00000google'))//true
    • [^a-z]表示取非,任意非小写字母
       var pattern1=/[^a-z]oogle/;
      alert(pattern1.test('0oogle'))//true
      alert(pattern1.test('google'))//flase
      alert(pattern1.test('Foogle'))//true

      当然也可以是任意非大写字母,非数字,非~

    • \w小写表示匹配字母数字及_
       var pattern1=/[a-zA-Z0-9_]oogle/;//可以被后者取代
      var pattern2=/\woogle/;
      alert(pattern2.test('_oogle'))//true
      alert(pattern2.test('.oogle'))//false
    • \W大写是小写的否定即,表示匹配任意非数字字母下划线
    • \d匹配数字
       var pattern1=/[0-9]oogle/;
      var pattern2=/\doogle/;
      alert(pattern2.test('2oogle'))//true
      alert(pattern2.test('.oogle'))//false
    • \D大写取非咯
  • 空白字符

    • \s表示空白匹配

      var pattern1=/goo\sgle/;
      alert(pattern1.test('goo gle'))//true
  • 锚字符

    • ^[]放在中括号外面哦,表示限制中括号内的内容出现在字符串的开始,
    • []$表示限制中括号的内容,或紧邻其的一个字符需要出现在字符串的结尾
       var pattern1=/^google$/;
      alert(pattern1.test('google'))//true
      var pattern2=/^google/;
      alert(pattern2.test('googleeeeee'))//true
      var pattern3=/google$/;
      alert(pattern3.test('gggggoogle'))//true
      var pattern1=/^google[0-9]$/;
      alert(pattern1.test('google7777'))//false
      alert(pattern1.test('google7'))//true
    • \b表示是否达到边界
       var pattern1=/google\b/;
      alert(pattern1.test('google'))//true
      var pattern1=/google\b/;
      alert(pattern1.test('googlee'))//flase
  • 重复字符
    • *表示匹配0个或任意多个*前面的字符

       var pattern1=/go*gle/;
      alert(pattern1.test('ggle'))//true
      alert(pattern1.test('gogle'))//true
      alert(pattern1.test('gooogle'))//true
    • +表示匹配1个或多个+前面的字符
      var pattern1=/go+gle/;
      alert(pattern1.test('ggle'))//false
      alert(pattern1.test('gogle'))//true
      alert(pattern1.test('gooogle'))//true
    • 表示匹配0个或一个?前面的字符
      var pattern1=/go?gle/;
      alert(pattern1.test('ggle'))//true
      alert(pattern1.test('gogle'))//true
      alert(pattern1.test('gooogle'))//false

      这个是表示对任意字符的重复限制。

      var pattern1=/g.?gle/;
      alert(pattern1.test('ggle'))//true
      alert(pattern1.test('gbgle'))//true
    • {m,n}匹配m~n个包括m与n个
       var pattern1=/go{2,4}gle/;
      alert(pattern1.test('gooooogle'))//false
      alert(pattern1.test('google'))//true

      表示只匹配限定个数个

       var pattern1=/go{2}gle/;
      alert(pattern1.test('gooooogle'))//false
      alert(pattern1.test('google'))//true

      表示至少匹配某个

       var pattern1=/go{2,}gle/;
      alert(pattern1.test('gooooogle'))//true
      alert(pattern1.test('google'))//true
    • ()+匹配至少一个模式
      var pattern1=/(google)+/;//对google这个字符串进行重复匹配
      alert(pattern1.test('googlegooglegoogle'))//true
  • 或字符
    或模式匹配
      var pattern1=/google|baidu|bing/;//或模式匹配
    alert(pattern1.test('this is baidu'))//true
    alert(pattern1.test('soso'))//false
  • 替代字符
      var pattern1=/(.*)\s(.*)/;//替换
    var str='google baidu';
    alert(str.replace(pattern1,'$2 $1'));//baidu google
    var pattern1=/8(.*)8/;//获取88之间的任意字符
    var str='this is 8google8';
    document.write(str.replace(pattern1,'<strong>$1</strong>'))
  • 记录字符
    • 分组

      var pattern1=/(google){2,4}/;//对google这个字符串进行重复匹配
      alert(pattern1.test('googlegooglegoogle'))//true
      alert(pattern1.test('google'))//flase
    • 捕获分组
      var pattern1=/8(.*)8/;//获取88之间的任意字符
      alert(pattern1.test('this is 8google8'))//true
      alert(RegExp.$1);//google表示获取模式中第一个分组对应的匹配的字符串,必须得运行过。

贪婪与惰性

  • 贪婪模式

      var pattern=/8(.*)8/;// 使用了贪婪,匹配到了google8 8google8 8google
    var str='8google8 8google8 8google8';
    document.write(str.replace(pattern,'<strong>$1</strong>'))
  • 惰性模式
      var pattern=/8(.*?)8/g;//惰性模式,全部匹配
    var str='8google8 8google8 8google8';
    document.write(str.replace(pattern,'<strong>$1</strong>'))

    在*后面多加一个?表示取消贪婪模式,进行惰性模式,只进行匹配一个。
    下面这个是没有采用惰性模式,只是将匹配的结果中除去了8

      var pattern=/8([^8]*)8/g;//惰性模式,全部匹配
    var str='8google8 8google8 8google8';
    document.write(str.replace(pattern,'<strong>$1</strong>'))

  • 捕获与非捕获
    未添加分组时:.exec只返回当前位置匹配的字符串

      var pattern=/[a-z]*\s\d{4}/;
    var str='google 2015';
    alert(pattern.exec(str));//google 2015

    添加分组后,该分组内容被捕获,并赋给exec所返回的数组

      var pattern=/([a-z]*)\s(\d{4})/;
    var str='google 2015';
    alert(pattern.exec(str));//google 2015,goole,2015

    非捕获即取消分组被捕获(?:)通过在分组前加上问号与冒号,便可以取消捕获该分组。

      var pattern=/([a-z]*)\s(?:\d{4})/;
    var str='google 2015';
    alert(pattern.exec(str));//google 2015,goole
  • 分组嵌套
    嵌套分组需要~从外往内获取~
      var pattern=/(a?(b?(c?)))/;
    var str='abc';
    alert(pattern.exec(str));//abc,abc,bc,c

    第一步:获得匹配字符串:abc
    第二步:获得第一个分组,即最外层:abc
    第三步:获得第二个分组,bc
    第四步:获得最内层分组c

  • 使用前瞻捕获
      var pattern=/goo(?=gle)/;
    var str='google';
    alert(pattern.exec(str));//goo

    在正则匹配的字符串之后添加一对(),该括号内定义了匹配条件,只有当满足条件时,才可以进行匹配。注意该例子的最后匹配值为goo。

  • 使用特殊字符匹配
      var pattern=/\[/;
    var str='[';
    alert(pattern.test(str));//true

    对于要匹配特殊最的情况,需要在其前加上斜杠,来标识。

  • 换行模式

      var pattern=/\d+/g;
    var str='1、abc\n2、edf';
    alert(str.replace(pattern,'#'));//完全匹配,并替换 var pattern=/^\d+/g;
    var str='1、abc\n2、edf';
    alert(str.replace(pattern,'#'));//匹配第一个 var pattern=/^\d+/gm;
    var str='1、abc\n2、edf';
    alert(str.replace(pattern,'#'));//完全匹配,并替换

    当字符串内出现换行符时,如果我们不进行锚字符的使用,那么会匹配全局,包括换行后的。
    但是,由于使用锚字符,导致即使使用了全局,也没有办法匹配换行后的结果,此时需要开启换行。

JS—正则表达式的更多相关文章

  1. JS正则表达式常用总结

    正则表达式的创建 JS正则表达式的创建有两种方式: new RegExp() 和 直接字面量. //使用RegExp对象创建 var regObj = new RegExp("(^\\s+) ...

  2. 使用外部web组件-----easyUI、jQueryUI、Bootstrap、js正则表达式

    1.使用外部web组件,以Bootstrap为例 <head> <link rel='stylesheet'  href='bootstrap-3.3.0-dist/dist/css ...

  3. js正则表达式图形化工具-rline

    github地址:https://github.com/finance-sh/rline 在线demo: http://lihuazhai.com/demo/test.html 这是一个js正则表达式 ...

  4. Python之路-(js正则表达式、前端页面的模板套用、Django基础)

    js正则表达式 前端页面的模板套用 Django基础 js正则表达式: 1.定义正则表达式 /.../  用于定义正则表达式 /.../g 表示全局匹配 /.../i 表示不区分大小写 /.../m ...

  5. JS正则表达式大全

    转自:http://wenku.baidu.com/link?url=3y930kC7F6D3wQdMjQ3fVDmiA9Wfebs_QK0UB3N3mFaEoKg4ytZORPopxufeYA6si ...

  6. js正则表达式replace里有变量的解决方法用到RegExp类

    一直比较害怕使用正则表达式,貌似很深奥很复杂的样子,所以在用js操作字符串的时候,我最多使用的是replace.split.substring.indexOf等函数,这些函数有时候需要多次叠加使用,但 ...

  7. JS正则表达式验证账号、手机号、电话和邮箱

    JS正则表达式验证账号.手机号.电话和邮箱 效果体验:http://keleyi.com/keleyi/phtml/jstexiao/15.htm 验证帐号是否合法 验证规则:字母.数字.下划线组成, ...

  8. 初识JS正则表达式

    初识JS正则表达式 看到的使用的正则表达式练习:http://www.cnblogs.com/wenanry/archive/2010/09/06/1819552.html PS:本文参考李炎恢JS笔 ...

  9. 常用JS正则表达式

    常用JS正则表达式 收集一些常用的JavaScript正则表达式匹配规则,比如匹配电话号码.Email.中文字符.身份证号.邮编.QQ号.过滤空白行.匹配特定数字等.觉得这玩意是很有用的,只不过自己水 ...

  10. JS正则表达式大全(整理详细且实用)

    JS正则表达式大全(整理详细且实用).需要的朋友可以过来参考下,希望对大家有所帮助!! 正则表达式中的特殊字符 字符 含意 \ 做为转意,即通常在"\"后面的字符不按原来意义解释, ...

随机推荐

  1. 算法(11)Find All Duplicates in an Array

    题目:数组的长度是n,里面的数是1到n,其中肯定有重复的,找到里面重复的数字 思路:自己想愣是没有想出来,直接看答案,关键点是看nums[i]和nums[nums[i]-1]之间的关系,遍历整个数组, ...

  2. 在fslook

    fslook让我们从内核看文件系统而不是从用户态,从这个工具中发现了很多之前忽略过的点. 1)overlay从内核中看到的文件的ino为什么和用户态stat中看到的ino不是一样的?

  3. npm基本使用

    常见的使用场景有以下几种: 允许用户从NPM服务器下载别人编写的第三方包到本地使用. 允许用户从NPM服务器下载并安装别人编写的命令行程序到本地使用. 允许用户将自己编写的包或命令行程序上传到NPM服 ...

  4. 一道前端面试题:定义一个方法将string的每个字符串间加个空格返回,调用的方式'hello world'.spacify();

    偶然在群里看到了这道题:定义一个方法将string的每个字符串间加个空格返回,调用的方式'hello world'.spacify(); 这道题主要是对JavaScript对象原型的考察.

  5. [洛谷P4940]Portal2

    题目大意:维护两个栈,几个操作: $PUSH\;x\;num:$把$num$压入栈$x$ $POP\;x:$弹出栈$x$栈顶元素 $ADD\;x:$取出两个栈栈顶,把相加值压入栈$x$ $SUB\;x ...

  6. [AT3857]Median Sum

    题目大意:给定$n$个数,第$i$个数为$a_i$,记这$n$个数的所有非空子集的和分别为$s_1,s_2,\dots,s_{2^n-1}$:求$s$的中位数. 题解:假设考虑的是所有子集,包括空子集 ...

  7. 【POJ 3169 Layout】

    Time Limit: 1000MSMemory Limit: 65536K Total Submissions: 12565Accepted: 6043 Description Like every ...

  8. NOIP2016愤怒的小鸟 [状压dp]

    愤怒的小鸟 题目描述 Kiana 最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于 (0,0) 处,每次 Kiana 可以用它向第一象限发射一只红色的小鸟, ...

  9. POJ 3104 Drying(二分

    Drying Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 22163   Accepted: 5611 Descripti ...

  10. 牛客多校对抗第6场 A Singing Contest

    [20分]标题:A.Singing Contest | 时间限制:1秒 | 内存限制:256MJigglypuff is holding a singing contest. There are 2n ...