这篇文章主要介绍了JS正则表达式常见用法,结合实例形式分析了javascript元字符、分组符、修饰符、量词基本含义,并结合具体案例形式分析了javascript正则基本使用技巧,需要的朋友可以参考下

本文实例讲述了JS正则表达式常见用法。分享给大家供大家参考,具体如下:

前言:正则表达式(regular expression)反反复复学了多次,学了又忘,忘了又学,这次打算把基本的东西都整理出来,加强记忆,也方便下次查询。

学习正则表达式之前首先需要掌握记忆这些基本概念:

1.元字符:(.,\w,\W,\d,\D,\s,/S,^,$,)

字符 含义
. 匹配除了换行符以外的任意字符。
\s 代表任意空白符(换行符,制表符,空格)
\S 匹配任意非空字符串
\b 匹配单词边界,匹配单词的开头和结尾。
\B 匹配一个非单词边界
\d 匹配一个数字,等价于[0-9]
\D 匹配一个非数字,等价于[^0-9]
\w 匹配一个单字字符(字母、数字或者下划线)等价于[A-Za-z0-9_],例如, /\w/ 匹配 "apple," 中的 'a',"$5.28,"中的 '5' 和 "3D." 中的 '3'。 \W匹配一个非单字字符。等价于[^A-Za-z0-9_],例如, /\W/ 或者 /[^A-Za-z0-9_]/ 匹配 "50%." 中的 '%'。
\W 匹配一个非单字字符。等价于[^A-Za-z0-9_],例如, /\W/ 或者 /[^A-Za-z0-9_]/ 匹配 "50%." 中的 '%'。
^ 匹配字符串的开始用在[]括号里面表示排除,/^A/ 并不会匹配 "an A" 中的 'A',但是会匹配 "An E" 中的 'A'。
$ 匹配字符串的结束。例如,/t$/ 并不会匹配 "eater" 中的 't',但是会匹配 "eat" 中的 't'。 QQ号必须为5位到12位数字时,可以使用:^\d{5,12}$

我们发现\W加大写字母都是表示相反的意思。

2.分组符([],(),{});

字符 含义
() 如果想要重复多个字符该怎么办?你可以用小括号来指定子表达式(也叫做分组),然后你就可以指定这个子表达式的重复次数了。eg: (\d{1,3}\.){3}\d{1,3}是一个简单的IP地址匹配表达式。要理解这个表达式,请按下列顺序分析它:\d{1,3}匹配1到3位的数字,(\d{1,3}\.){3}匹配三位数字加上一个英文句号(这个整体也就是这个分组)重复3次,最后再加上一个一到三位的数字(\d{1,3})。
[] 代表一个字符集合。匹配方括号的中任意字符,包括转义序列。你可以使用破折号(-)来指定一个字符范围。对于点(.)和星号(*)这样的特殊符号在一个字符集中没有特殊的意义。他们不必进行转义,不过转义也是起作用的。例如,[abcd] 和[a-d]是一样的。他们都匹配"brisket"中得‘b',也都匹配“city”中的‘c'。/[a-z.]+/ 和/[\w.]+/都匹配“test.i.ng”中得所有字符。
{} 表示量词的范围的。

3.修饰符(i,g,m);

字符 含义
i 忽略大小写
g 执行全局匹配
m 执行多行匹配

4.量词(*,?,+,-,{n,m},?=n,?!=n);

字符 含义
* 匹配任意次,.*连在一起就意味着任意数量的不包含换行的字符。等价于{0,}
+ 匹配前面一个表达式1次或者多次。等价于 {1,}。
? 匹配前面一个表达式0次或者1次。等价于 {0,1}。
{n,m} 匹配n到m次
x(?=y) 匹配'x'仅仅当'x'后面跟着'y'.这种叫做正向肯定查找。 例如,/Jack(?=Sprat)/会匹配到'Jack'仅仅当它后面跟着'Sprat'。/Jack(?=Sprat|Frost)/匹配‘Jack'仅仅当它后面跟着'Sprat'或者是‘Frost'。但是‘Sprat'和‘Frost'都不是匹配结果的一部分。
x(?!y) 匹配'x'仅仅当'x'后面不跟着'y',这个叫做正向否定查找。 例如,/\d+(?!\.)/匹配一个数字仅仅当这个数字后面没有跟小数点的时候。正则表达式/\d+(?!\.)/.exec("3.141")匹配‘141'但是不是‘3.141'

实例解析:

1

var reg = /\(?0\d{2}[) -]?\d{8}/

“(”和“)”也是元字符,后面的分组节里会提到,所以在这里需要使用转义。
这个表达式可以匹配几种格式的电话号码,像(010)88886666,或022-22334455,或02912345678等。我们对它进行一些分析吧:首先是一个转义字符\(,它能出现0次或1次(?),然后是一个0,后面跟着2个数字(\d{2}),然后是)或-或空格中的一个,它出现1次或不出现(?),最后是8个数字(\d{8})。

以下通过实例来讲解RegExp:

需求一:在一句话英文中匹配一个hi的单词。

1

2

3

4

5

6

7

8

9

10

var str = 'Hi RegExp I love you so much Hi Hi hi';

var reg = new RegExp("\\bhi\\b","gi");//g是一个修饰符,表示全局匹配。\b是一个元字符,代表单词边界,匹配单词的开头和结尾。

//直接量语法:

reg2 = /\bhi\b/gi;

console.log(str.match(reg2));//['hi','hi','hi','hi']

//升级

//匹配hi后面不远处跟着一个lucy

var strlc = /\bhi\b.*\blucy\b/;

var luch = 'hi welcome to beijing lucy!!!';

console.log(luch.match(strlc));

需求二:在一句话英文中匹配一个hi的单词。

1

2

3

4

5

6

var reg = /0\d\d\d-\d\d\d\d\d\d\d\d/;//\d代表一个数字,等价于[0-9],\D匹配一个非数字字符,等价于[^0-9]

var tel = "0123-887523146";

console.log(tel.match(reg));//0123-88752314;

//这个连续写多次的方法很笨哎,所以引进了变量。

regTel = /0\d{3}-\d{8}/;

console.log(tel.match(regTel));//0123-88752314;

需求三:写一个清除字符串前后空格的正则表达式。

1

2

3

4

5

String.prototype.trim = function(){return this.replace(/(^\s*)|(\s*$)/g, "");}

var str2 = " hi space "//这里前后共有两个空格

console.log(str2.length);//14

console.log(str2.trim().length);//8

console.log(str2.trim());//hi space

需求四:匹配一个邮箱。

1

2

var eReg = /\S*@\S*\.\S*/;

console.log(eReg.test('873619879@qq.com'))//true

参考文章:

https://www.jb51.net/books/513871.html
https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Guide/Regular_Expressions#
//www.jb51.net/article/72867.htm
https://www.jb51.net/article/107796.htm

PS:这里再为大家提供2款非常方便的正则表达式工具供大家参考使用:

JavaScript正则表达式在线测试工具:
http://tools.jb51.net/regex/javascript

正则表达式在线生成工具:
http://tools.jb51.net/regex/create_reg

更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript正则表达式技巧大全》、《JavaScript替换操作技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》、《JavaScript中json操作技巧总结》、《JavaScript错误与调试技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

您可能感兴趣的文章:

  • JS正则表达式大全(整理详细且实用)
  • 比较正宗的验证邮箱的正则表达式js代码详解
  • javascript 手机号码正则表达式验证函数
  • js 常用正则表达式表单验证代码
  • JS正则表达式验证数字代码
  • JavaScript正则表达式验证身份证号码是否合法(两种方法)
  • 精通JS正则表达式(推荐)
  • 用户名、密码等15个常用的js正则表达式
  • js各种验证文本框输入格式(正则表达式)
  • js正则表达式中test,exec,match方法的区别说明
  • js 替换功能函数,用正则表达式解决,js的全部替换

JS正则表达式常见用法实例详解相关推荐

  1. js事件监听器用法实例详解

    这篇文章主要介绍了js事件监听器用法,以实例形式较为详细的分析了javascript事件监听器使用注意事项与相关技巧,需要的朋友可以参考下 本文实例讲述了js事件监听器用法.分享给大家供大家参考.具体 ...

  2. oracle几种例外,Oracle例外用法实例详解

    本文实例讲述了Oracle例外用法.分享给大家供大家参考,具体如下: 一.例外分类 oracle将例外分为预定义例外.非预定义例外和自定义例外三种. 1).预定义例外用于处理常见的oracle错误. ...

  3. python编程字典100例_python中字典(Dictionary)用法实例详解

    本文实例讲述了python中字典(Dictionary)用法.分享给大家供大家参考.具体分析如下: 字典(Dictionary)是一种映射结构的数据类型,由无序的"键-值对"组成. ...

  4. mysql数据库select语句用法_mysql学习笔记之完整的select语句用法实例详解

    本文实例讲述了mysql学习笔记之完整的select语句用法.分享给大家供大家参考,具体如下: 本文内容: 完整语法 去重选项 字段别名 数据源 where group by having order ...

  5. python中symbols函数用法_Python基础之函数用法实例详解

    本文以实例形式较为详细的讲述了Python函数的用法,对于初学Python的朋友有不错的借鉴价值.分享给大家供大家参考之用.具体分析如下: 通常来说,Python的函数是由一个新的语句编写,即def, ...

  6. python 正则式替换_python 正则表达式参数替换实例详解

    正则表达式是一个特殊的字符序列,它能帮助你方便的检查一个字符串是否与某种模式匹配. Python 自1.5版本起增加了re 模块,它提供 Perl 风格的正则表达式模式. re 模块使 Python ...

  7. python的scatter函数_python scatter函数用法实例详解

    这篇文章主要介绍了python scatter函数用法实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 函数功能:寻找变量之间的关系. 调用签 ...

  8. c语言pair的用法,C++ pair的用法实例详解

    C++ pair的用法实例详解 1 pair的应用 pair是将2个数据组合成一个数据,当需要这样的需求时就可以使用pair,如stl中的map就是将key和value放在一起来保存.另一个应用是,当 ...

  9. python3.5怎么使用-Python3.5常见内置方法参数用法实例详解

    本文实例讲述了Python3.5常见内置方法参数用法.分享给大家供大家参考,具体如下: Python的内置方法参数详解网站为:https://docs.python.org/3/library/fun ...

最新文章

  1. MySQL☞dual虚拟表
  2. x window的奥秘
  3. 基于Windows环境下MyEclipse10快捷键总结
  4. 5月9日 python学习总结 外键、表之间的关联关系、修改表、清空表内容、复制表...
  5. linux下删除乱码文件名的方法
  6. Android远程调试的探索与实现
  7. 中国科学院大学庆生 一颗小行星以“国科大”命名
  8. 教你怎么使用你的电脑
  9. 华为云发布【云巢】智慧康养物联网加速器,加入立享多项扶持
  10. Python 列表实现原理
  11. 特征选择---文本分类:叉方统计量 卡方
  12. mysql中日期相减_1104绝密公式,如何直接用2个日期直接算剩余时间区间
  13. 基本比例尺标准分幅编号流程
  14. 电子书免费下载及文本格式转换问题
  15. s7 modbus测试软件,S7-1200 Modbus-Tcp通讯测试
  16. 阿里腾讯大裁员,中概股暴跌!没病千万别去互联网公司......
  17. PTA-1021-Deepest Root
  18. 用计算机绘制函数图像数学大师,什么手机app可以画函数图像 能画函数图像的app推荐...
  19. 汉诺塔(河内塔)问题(递归)
  20. Xcode菜单及常用快捷键大全

热门文章

  1. windows 无法更新计算机启动配置,“windows 无法更新计算机的启动配置。安装无法继续”这样解决...
  2. 从此爱情与我无关,只做一个嗜钱如命的渣男!
  3. 3、vue-路由、拦截器和嵌套路由
  4. python使用numba库实现gpu加速
  5. 无法定位程序输入点?isPublicID@QXmlUtils@@SA_NAEVVQString@@@Z于动态链接库 D:\Qt\Qt5.7.0\5.7\msvc2015_64\bin\Qt5Cored
  6. 笔记本不显示计算机储存盘,电脑开机黑屏只有鼠标箭头的解决办法 电脑硬盘无法分区怎么办...
  7. 龚鹏:我是怎么从程序员成为全栈GEEK的
  8. 再见2018,感谢你的一路陪伴
  9. 项目中生成requests.txt文件(virtualenv与pipreqs)
  10. 整数:求数组Nums中只出现一次的数