1、分组之exec返回数组

1》非分组匹配的exec返回数组:

 var pattern =/\d+[a-z]+/;
var str='234google';
alert(pattern.exec(str)); //234google
alert(typeof pattern.exec(str)); //object

2》分组匹配下的exec返回数组

 pattern =/(\d+)([a-z]*)/;
var a =pattern.exec(str);
alert(a); //234google,234,google
alert(a.length); //
alert(a[0]); //234google :返回 匹配到的总的字符串
alert(a[1]); //234 :返回 匹配到的 第一个分组的字符串
alert(a[2]); //google :返回 匹配到的第二个分组的字符串

3》捕获分组和不捕获分组

上面第二种的 分组 匹配下的exec()就是 捕获分组。

不捕获分组,就是在不想捕获的分组匹配字符串前面 加上‘?:’,那么在匹配的时候就不会捕获这个模式字符串

 //下面是捕获分组
var pattern =/(\d+)\s([a-z]+)/;
var str='123 abc';
var a=pattern.exec(str);
alert(a); //123 abc,123,abc //不捕获分组
var pattern2=/(\d+)\s(?:[a-z]+)/; //在分组前面加上 "?:" 表示这个分组 在匹配的时候 不捕获
var str='123 abc';
var a=pattern2.exec(str);
alert(a); //123 abc,123 :注意:abc 这个 分组没有被捕获
alert(a.length); //

4》分组嵌套的捕获

对应嵌套分组的模式字符串,在捕获的时候是“从外向内”进行捕获的。

 var pattern =/(a?(b?(c?)))/;
var str='abc';
var a =pattern.exec(str); // 分组嵌套匹配 的获取是 “从外向内” 进行捕获的
alert(a[0]); //abc 返回:匹配到的 总 字符串
alert(a[1]); //abc 返回:返回第一个分组 的匹配 字符串(从外向内)
alert(a[2]); //bc 返回:第二个分组 匹配到的字符串
alert(a[3]); //c 返回:返回第三个分组匹配到的 字符串

2、前瞻捕获

匹配字符串的时候只匹配,符合自己要求的字符串,捕获也是同样的

先看示例:

 var pattern =/goo/;
var str='goobb';
alert(pattern.exec(str)); //返回 goo

如果只想要,goo后面的 是gle的 时候才匹配成功和 捕获,就要使用前瞻捕获进行限制

 pattern=/goo(?=gle)/;   //前瞻匹配:要求 goo 后面必须是  gle 才能匹配上
var str='goobb';
alert(pattern.exec(str)); //null
alert(pattern.test('google'));//true
alert(pattern.exec('google')); //goo

3、正则表达式中特殊字符的匹配

如果 匹配字符串中  含有 正则表达式中 特殊字符串,那么就 要用 \ 进行转义 之后才能使用,否则会报错

 var pattern =/\./;
var str='.';
alert(pattern.test(str));//true

4、常用正则表达式练习

写正则表达式的时候,最好先把测试的示例,然后总结出需求,然后再写正则表达式

1》邮编的验证

先写出一个示例:

var str='This is 124000!';  //由此可知要求是:6位字符, 要求都是数字  ,第一 字符大于 0

 var pattern =/[1-9][0-9]{5}/;  //如果想要  除了 邮政编码 什么都不需要,就 可以 加上 行首和行尾 匹配 '^$'
var str='This is 124000!'; //由此可知要求是:6位字符, 要求都是数字 ,第一 字符大于 0
alert(pattern.test(str)); //true

2》 压缩包 的匹配

示例:

var str='12_3.rar';    //要求:文件名:字母、数字、_,,然后是 . ,,最后是 zip或者 rar

 var pattern =/^(\w+)\.(zip|rar|7z|gz)$/;  //限定 行首和行尾 匹配
var str='12_3.rar'; //要求:文件名:字母、数字、_,,然后是 . ,,最后是 zip或者 rar alert(pattern.test(str));

3》 删除多余的 空格

删除字符串中所有的空格,这个很简单

var pattern =/\s/g;
var str='aa bbb cccc dd';
alert(str.replace(pattern,''));

删除首尾的空格 

1)最简单、最shit的写法

 var pattern =/^\s+/;
var str=' goo gle ';
var result =str.replace(pattern,'');
pattern =/\s+$/;
result =result.replace(pattern,'');
alert('|' +result + '|');

2)使用惰性模式的捕获

 var pattern =/^\s+(.*?)\s+$/;   //加上 ? 使用惰性模式,(因为贪婪模式:会将 后面的空格也匹配到 分组的模式字符串 里面),,所以在先 匹配首位之后,,再匹配 分组中的时候 不在 匹配 行尾匹配到的字符串
var str=' goo gle ';
//使用 exec()的 捕获
var result =pattern.exec(str)[1];
alert('|' + result + '|');

3)使用分组获取

 var pattern =/^\s+(.*?)\s+$/;
var str=' goo gle ';
var result =str.replace(pattern,'$1'); //取到 分组 匹配的 字符串然后 替代字符串
alert('|' + result + '|');

4》简单单子邮箱的验证

示例:

var str='gg60.shit@gmail.com';   //格式:'用户名(字母、数字、 .

 var pattern =/^([\w\.\-]+)@([\w\-]+)\.([a-zA-Z]{2,4})$/;
var str='gg60.shit@gmail.com'; //格式:'用户名(字母、数字、 . 、-、_)@域名(字母、数字、-).com/cn等(字母(2-4位))'
alert(pattern.test(str));

js之正则表达式(下)的更多相关文章

  1. js常用正则表达式2

    字符 含意 \ 做为转意,即通常在"\"后面的字符不按原来意义解释,如/b/匹配字符"b",当b前面加了反斜杆后/\b/,转意为匹配一个单词的边界. -或- 对 ...

  2. Js用正则表达式验证字符串

    js 常用正则表达式表单验证代码 作者: 字体:[增加 减小] 类型:转载 js 常用正则表达式表单验证代码,以后大家就可以直接使用了. 正则表达式使用详解 简介 简单的说,正则表达式是一种可以用于模 ...

  3. AngularJS进阶(十三)JS利用正则表达式校验手机号

    JS利用正则表达式校验手机号 注:请点击此处进行充电! 绪 由于项目需求,需要在前端实现手机号码的校验.当然了,对于基本的格式校验应该放在客户端进行,而不需要再将待校验的手机号发送至服务端,在服务端完 ...

  4. JS常用正则表达式备忘录

    摘要: 玩转正则表达式. 原文:JS常用正则表达式备忘录 作者:前端小智 Fundebug经授权转载,版权归原作者所有. 正则表达式或"regex"用于匹配字符串的各个部分 下面是 ...

  5. JS的正则表达式简介

    1.JS的正则表达式 1.1 简介 JS的正则表达式比较简单,总体上只分为两个功能:一个是test——用于匹配字符串是否符合规定的正则表达式规则:另外一个是exec——用于获取匹配到的数据. 1.2 ...

  6. Js与正则表达式

    原本接着上面的章节,这一章节应该是写 Jquery事件的,由工作需要,暂时横插一篇正则表达式的学习,这里是边学边记录,错误之处,希望指正,提拔一二,不甚感激! 此章节有 1.1 正则表达式的定义 1. ...

  7. js常用正则表达式,滚蛋吧!你们测试组bug,让你挑

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  8. JS 之正则表达式

    字符 含意 \ 做为转意,即通常在"\"后面的字符不按原来意义解释,如/b/匹配字符"b",当b前面加了反斜杆后/\b/,转意为匹配一个单词的边界. -或- 对 ...

  9. js课程 4-12 js中正则表达式如何使用

    js课程 4-12 js中正则表达式如何使用 一.总结 一句话总结: 1.js正则表达式手册取哪里找? w3cschool或者菜鸟教程->找到js正则表达式->完整的RegExp参考手册这 ...

  10. js进阶正则表达式13RegExp对象方法(RegExp对象的方法:compile,test,exec)(子表达式 var reg1=/([a-z]+)\d/)

    js进阶正则表达式13RegExp对象方法(RegExp对象的方法:compile,test,exec)(子表达式 var reg1=/([a-z]+)\d/) 一.总结 1.RegExp对象有三个方 ...

随机推荐

  1. IO输入输出 3

    编写BinIoDemo.java的Java应用程序,程序完成的功能是:完成1.doc文件的复制,复制以后的文件的名称为自己的学号姓名.doc. package com.hanqi.test; impo ...

  2. 如何提高手机APP的用户体验?

    详细内容请点击 随着移动互联网如日中天,如火如荼的时候,手机APP开发日益高涨了起来,关于手机APP的用户体验,也是一个老话长谈的话题.从事这行业也很久了,以下是我个人在工作中的一些关于APP的用户体 ...

  3. 正则表达式删除指定的HTML 标签

    1.抓取某网页的数据后(比如描述),如果照原样显示的话,可能会因为它里面包含没有闭合的HTML标签而打乱了格式,也可能它里面用了比较让人 "费解" 的HTML标签,把预订的格式搅乱 ...

  4. ListView优化-getView优化

    ListView作为Android中最常用的组件之一,其优化方式也比较多. 在使用ListView或是GridView的时候,往往需要自定义数据适配器.一般我们都需要复习getView方法.对于此方法 ...

  5. IOS显示九宫格列表

    //总列数 ; CGFloat appW = ; CGFloat appH = ; //间隙 CGFloat maginX = (self.view.frame.size.width - totalC ...

  6. 【C语言】02-函数

    一.函数的分类 前面已经说过,C语言中的函数就是面向对象中的"方法",C语言的函数可以大概分为3类: 1.主函数,也就是main函数.每个程序中只能有一个.也必须有一个主函数.无论 ...

  7. .NET中导入导出Excel总结

    前一段时间,做了Excle的导入和导出,在此记录开发思路及技术要点,以便在今后开发中参考.                                                        ...

  8. (转)Linux概念架构的理解

    英文原文:Conceptual Architecture of the Linux Kernel 摘要 Linux kernel成功的两个原因:(1)架构设计支持大量的志愿开发者加入到开发过程中:(2 ...

  9. 如何给xml应用样式

    引子:可扩展标记语言xml(Extensible Markup Language)自己平常也用到的不多,除了在ajax处理服务器返回的数据可能会用到外(不过一般用json处理数据的比较常见)还真没怎么 ...

  10. Linux 静态库和动态库 使用说明

        Linux下程序运行中,有两种库,静态库和动态库.     静态库:名字一般为libxxx.a,编译时会整合到可执行程序中,优点是运行时不需要外部函数库支持,缺点是编译后程序较大,一旦静态库改 ...