js正则表达式教程示例

正则表达式是项目开发中常用的模式,内容替换、表单认证、网络爬虫等,通过以下的例子我相信可以大概掌握正则表达式了

定义字符集 []

  • [a-e]表示a到e这些字符中的某一个字符

  • [a-z]26个字母之一

  • [aeiou]表示aeiou这5个字符其中的某一个字符

  • [a-zA-Z]表示大写、小写字母中的某一个字符

  • [a-zA-Z0-9_-]表示大写、小写字母、0-9、_、-中的某一个字符

  • [0-9]表示0到9之间的任意一个数字

  • [9-3] [z-a]不能从大往小写,有语法错误

     <script type="text/javascript">
         //定义字符集
         //在没有特殊限制的时候就是“单次”匹配
         //从左往右匹配到第一符合模式的内容即可
    
         var str = "2015-09-12 is a SunShine Day";
         var reg = /[a-z]/;   //["i"]
         var reg = /[M-W]/;   //["S"]
         var reg = /[uxpq]/;  //["u"]
         var reg = /[0-9]/;   //["2"]
         var reg = /[a-z_-]/; //["-"]
         var rst = str.match(reg);
         console.log(rst);
         
     </script>
    

特别字符集

  • $:匹配输入字符串的结尾位置

  • ^(托字符):表示字符串的开始位置,或者表示非

  • ():标记一个字表达式的开始和结束位置

  • :其前面那个单元出现0次或以上(任意次数)*

  • +:其前面那个单元出现1次或以上

  • ?:其前面那个单元出现0次或者1次

  • .点:匹配除换行符\n之外的任何单字符

  • \:用来转义的符号

  • |:表示两个之间的一个选择,或

     <script type="text/javascript">
         //特别字符集
    
         //*  ?  +
         var str = "2018-03-01 is a SunShine Day";
         var reg = /[0-9]+/;   //["2018"]
         
         var str = "gooogle";
         var reg = /go+gle/; //["gooogle"]
    
         var str = "ggle";
         var reg = /go*gle/; //["ggle"]
         
         var str = "hellow 0 javascript";
         var reg = /[0-9]+/; //["0"]
         var reg = /[0-9]*/; //[""]匹配空的字符串,因为开始的时候就出现了0次,"没有"
         var reg = /loe?w/; //["low"]
         
         var rst = str.match(reg);
         console.log(rst);
         
         //.点  \  |
         var str = "svovk(dsf?>?*&{})!^\n}PPoo*&?";
         var reg = /.*/; //["svovk(dsf?>?*&{})!^"]
         
         var str = "xiaoming like eat apple";
         var reg = /banana|apple/; //["apple"]
         
         var str = '<div class="box">the box</div>';
         var reg = /<div class=\"box\">the .*<\/div>/; //["<div class="box">the box</div>"]转义在正则中有特殊含义的字符,例如| / . ? + 等
         var rst = str.match(reg);
         console.log(rst);
         
         
         //^和$符号
         var str = "php is the best language";
         var reg = /[language]/; //["language"]
         var reg = /[^language]/; //null 'language'在字符串的开始位置没有出现
         var reg = /[^php]/; //["php"]
         
         var reg = /[languag$]/; //null 'languag'在字符串的结尾位置没有出现
         var reg = /language$/; //["language"]
         
         //^和$两符号要出现在每个正常的正则表达式里边
    

    //作用:可以“完整”地匹配输入字符串的信息
    //手机号码验证:13开始,后续有9位数字,不能添加其余内容
    var str = "13250185056";
    var reg = /^13[0-9]{9}$/;//{m}前面单元严格出现m次
    var rst = str.match(reg);
    console.log(rst);

        //()小阔号
        //作用:
        //提高字表达式优先级
        //从一个大的字符串中拆分小的字符串出来
        var str = "gogle";
        var reg = /(go)+(gle)/;
        
        //rst[0] = "gogle";成功匹配的字符串
        //rst[1] = "go";第一个()里面匹配成功的字符串,不成功为undefined
        //rst[2] = "gle"第二个()里面匹配成功的字符串,不成功为undefined
        
        //提取html里面的关键内容
        var str = '<div id="today" class="tqingtoday"><h3 style="padding-bottom:0px;">北京</h3><ul><li class="tqpng_01"><li class="sd">晴</li><li class="font_05">';
        var reg = /<h3.*>(.*)<\/h3>/;
        var rst = str.match(reg);
        console.log(rst[0]);//"<h3 style="padding-bottom:0px;">北京</h3>"
        console.log(rst[1]);//"北京",成功提取出北京
    </script>
  • ()小括号使用扩展

     <script type="text/javascript">
         //小括号模式单元 重复使用
    
         var str = "2018-09-09 09:09:09";
         //匹配到的时间特点:月份、日期、时、分、秒都一致
         var reg = /[0-9]+-[0-9]+-[0-9]+ [0-9]+:[0-9]+:[0-9]+/; // ["2018-09-09 09:09:09"]
         //通过“\1”重复匹配前面第一个小括号模式单元内容
         var reg = /[0-9]+-([0-9]+)-\1 \1:\1:\1/; // ["2018-09-09 09:09:09","09"]
         //通过“\2”重复匹配前面第二个小括号模式单元内容
         var reg = /([0-9]+)-([0-9]+)-\2 \2:\2:\2/; //["2018-09-09 09:09:09","2018","09"]
         
         var str = "2018:11 2018&11";
         var reg = /([0-9]+):([0-9]+) \1&\2/; //["2018:11 2018&11","2018","11"]
         
         //\m模式单元重复使用 与 {m}、+、*的区别:
         //1、\m\m\m\m 限制前面单元出现多次
         //   重复匹配前面第m个小括号内容
         //   要求 匹配内容与被匹配内容的“大小和数据类型”都一致
         //2、{m}、+、*限制前面单元出现多次,出现的内容只要保证“数据类型”一致即可
         
         var str1 = "2018-03-03-03-03-03";
         var str2 = "2018-03-12-15-23-57";
         
         var reg = /[0-9]+(-[0-9]+)\1\1\1\1/; //["2018-03-03-03-03-03","-03"] null(str2匹配不成功)
         
         var reg = /[0-9]+(-[0-9]+){5}/; //["2018-03-03-03-03-03","-03"] ["2018-03-03-03-03-03","-57"]
         
         //{5}、+、* 匹配以上两个str效果一样
         
         
         var rst = str.match(reg);
         console.log(rst);
         
     </script>
    

模式修正符

var 模式名称 = /模式内容/模式修正符;

  • i:忽略大小写

  • g:全局匹配(进行全局匹配的时候不给体现"模式单元"内容,默认是单次匹配,非全局)

     <script type="text/javascript">
         //模式修正符
    
         var str = "Beijing2008Guangzhou2010Shanghai2012";
         var reg = /[a-z]+([0-9]+)/ig;
         var rst = str.match(reg);
         console.log(rst);
         //["Beijing2008","Guangzhou2010","Shanghai2012"],没有index和input属性,不获取()里面的内容
         
     </script>
    

组合字符集

  • \d:表示数字[0-9]

  • \D:表示非数字[^0-9]

  • \w:表示字母、数字、下划线中其中一个[a-zA-Z0-9_]

  • \W:非字母、数字、下划线[^a-zA-Z0-9_]

  • \s:表示空格

  • \S:表示非空格

     <script type="text/javascript">
         //组合字符集
         //\d:表示数字[0-9] \D:表示非数字[^0-9]
         var str = "2018/03/01";
         var reg = /\d+/; //["2018"]
         var reg = /\D/g; //["/","/"]
         var reg = /[^0-3]+/; //["8/"]
         
         //\w:表示字母、数字、下划线中其中一个[a-zA-Z0-9_] \W:非字母、数字、下划线[^a-zA-Z0-9_]
         var str = "asdas326_JIO@jiaying.yang";
         var reg = /\w+/; //["asdas326_JIO"]
         var reg = /\W/g; //["@","."]
         
         //s:表示空格 \S:表示非空格
         var str = "hellow      guangzhou";
         var reg = /[a-z]+\s\s\s\s\s\s[a-z]+/; //["hellow      guangzhou"]       
    
         var rst = str.match(reg);
         console.log(rst);
         
     </script>
    

限制字符集

  • {m}:前面单元出现m次
  • {m,}:前面单元至少出现m次,至多不限制
  • {m,n}:前面单元出现至少m次,至多n次
  • [^lsdf]:不是中括号中的任意一个字符
  • [^a-f]:不是中括号中范围的任意一个字符
  • var reg = /^apple/; 匹配内容开始有apple字样
  • var reg = /[^a-h]/; 不匹配a-h之间的字母

正向反向匹配

  • 正向匹配:我们要查找出来的内容,右边必须出现指定的信息,并且其是辅助条件,不是结果的一部分。
    var reg = /pattern(?=模式)/;

  • 正向不匹配:我们要查找出来的内容,右边不能出现指定的信息,右边的信息是辅助条件,非结果部分。
    var reg = /pattern(?!模式)/;
    例如:

     <script type="text/javascript">
         //正向匹配:小写字母字符串右边要出现连续数字信息
         
         var str1 = "javascript2018";
         var str2 = "javascript@2018";
         var reg = /[a-z]+(?=\d+)/; //["javascript"] 不匹配模式里面的内容  null没有在右边出现连续数字
         
         var str = "https://www.bmob.cn/shop/index.php?price=50&platform=0&type=2"
         //通过正向匹配获取参数名称 price、platform、type
         var reg = /[a-z]+(?==)/g; //["price","platform","type"]
         
         
         //正向不匹配:右边不能出现连续数字信息
         var str1 = "todayABC254";
         var str2 = "today123";
         var reg = /[a-z]+(?!\d+)/; //["today"] 不匹配模式里面的内容  null在右边出现了连续数字
         
         
         var rst = str.match(reg);
         console.log(rst);
         
     </script>
    
  • 反向匹配:左边必须出现指定信息
    var reg = /(?<=模式)pattern/;

  • 反向不匹配:左边不能出现指定信息
    var reg = /(?<!模式)pattern/;

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,245评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,749评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,960评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,575评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,668评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,670评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,664评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,422评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,864评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,178评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,340评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,015评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,646评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,265评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,494评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,261评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,206评论 2 352

推荐阅读更多精彩内容