javascript学习笔记(八)正则表达式


Posted in Javascript onOctober 08, 2014

基本概念

正则表达式是一种文本模式,包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为“元字符”)。模式描述在搜索文本时要匹配的一个或多个字符串。

首先推荐几个正则表达式编辑器
 Debuggex :https://www.debuggex.com/
 PyRegex:http://www.pyregex.com/
 Regexper:http://www.regexper.com/

正则表达式是一种查找以及字符串替换操作。正则表达式在文本编辑器中广泛使用,比如正则表达式被用于:
[copy]检查文本中是否含有指定的特征词
找出文中匹配特征词的位置
从文本中提取信息,比如:字符串的子串
修改文本

 说明:正则表达式通常用于两种任务:1.验证,2.搜索/替换。用于验证时,通常需要在前后分别加上^和$,以匹配整个待验证字符串;搜索/替换时是否加上此限定则根据搜索的要求而定,此外,也有可能要在前后加上\b而不是^和$。此表所列的常用正则表达式,除个别外均未在前后加上任何限定,请根据需要,自行处理。

优先权顺序

在构造正则表达式之后,就可以象数学表达式一样来求值,也就是说,可以从左至右并按照一个优先权顺序来求值。 下表从最高优先级到最低优先级列出各种正则表达式操作符的优先权顺序:

操作符 描述
\ 转义符
(), (?:), (?=), [] 圆括号和方括号
*, +, ?, {n}, {n,}, {n,m} 限定符
^, $, \anymetacharacter 位置和顺序

建立正则表达式

构造正则表达式的方法和创建数学表达式的方法一样。也就是用多种元字符与操作符将小的表达式结合在一起来创建更大的表达式。
 可以通过在一对分隔符之间放入表达式模式的各种组件来构造一个正则表达式。

对 JScript 而言,分隔符为一对正斜杠 (/) 字符。例如:
/expression/

 对 VBScript 而言,则采用一对引号 ("") 来确定正则表达式的边界。例如:

"expression"

 看个例子

//匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线
var re =new RegExp("^[a-zA-Z][a-zA-Z0-9_]{5,19}$");

if(re.test(aaaa)){

alert("格式正确");

}else{

alert("格式错误");

}

 正则表达式的组件可以是单个的字符、字符集合、字符范围、字符间的选择或者所有这些组件的任意组合。

常用的正则表达式

匹配中文字符的正则表达式: [\u4e00-\u9fa5]
 评注:匹配中文还真是个头疼的事,有了这个表达式就好办了

匹配双字节字符(包括汉字在内):[^\x00-\xff]
 评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)

匹配空白行的正则表达式:\n\s*\r
 评注:可以用来删除空白行

匹配HTML标记的正则表达式:<(\S*?)[^>]*>.*?</\1>|<.*? />
 评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力

匹配首尾空白字符的正则表达式:^\s*|\s*$
 评注:可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式

匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
 评注:表单验证时很实用

匹配网址URL的正则表达式:[a-zA-z]+://[^\s]*
 评注:网上流传的版本功能很有限,上面这个基本可以满足需求

匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
 评注:表单验证时很实用

匹配国内电话号码:\d{3}-\d{8}|\d{4}-\d{7}
 评注:匹配形式如 0511-4405222 或 021-87888822

匹配腾讯QQ号:[1-9][0-9]{4,}
 评注:腾讯QQ号从10000开始

匹配中国邮政编码:[1-9]\d{5}(?!\d)
 评注:中国邮政编码为6位数字

匹配身份证:\d{15}|\d{18}
 评注:中国的身份证为15位或18位

匹配ip地址:\d+\.\d+\.\d+\.\d+
 评注:提取ip地址时有用

匹配特定数字
[copy] ^[1-9]\d*$    //匹配正整数
^-[1-9]\d*$   //匹配负整数
^-?[1-9]\d*$

//匹配整数
^[1-9]\d*|0$  //匹配非负整数(正整数 + 0)
^-[1-9]\d*|0$

//匹配非正整数(负整数 + 0)
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$

//匹配正浮点数
^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$  //匹配负浮点数
^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$  //匹配浮点数
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$

//匹配非负浮点数(正浮点数 + 0)
^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$

//匹配非正浮点数(负浮点数 + 0)

 评注:处理大量数据时有用,具体应用时注意修正

匹配特定字符串
[copy]^[A-Za-z]+$

//匹配由26个英文字母组成的字符串
^[A-Z]+$

//匹配由26个英文字母的大写组成的字符串
^[a-z]+$

//匹配由26个英文字母的小写组成的字符串
^[A-Za-z0-9]+$

//匹配由数字和26个英文字母组成的字符串
^\w+$

//匹配由数字、26个英文字母或者下划线组成的字符串

 评注:最基本也是最常用的一些表达式

思维导图

javascript学习笔记(八)正则表达式

Javascript 相关文章推荐
JavaScript 学习 - 提高篇
Feb 02 Javascript
js调试系列 断点与动态调试[基础篇]
Jun 18 Javascript
JavaScript设计模式之工厂方法模式介绍
Dec 28 Javascript
在JS方法中返回多个值的方法汇总
May 20 Javascript
XML文件转化成NSData对象的方法
Aug 12 Javascript
利用bootstrapValidator验证UEditor
Sep 14 Javascript
基于jQuery实现歌词滚动版音乐播放器的代码
Sep 17 Javascript
Angular.js自定义指令学习笔记实例
Feb 24 Javascript
canvas实现图片根据滑块放大缩小效果
Feb 24 Javascript
微信小程序使用map组件实现解析经纬度功能示例
Jan 22 Javascript
VUE脚手架的下载和配置步骤详解
Apr 01 Javascript
vue2 拖动排序 vuedraggable组件的实现
Aug 08 Javascript
javascript学习笔记(七)Ajax和Http状态码
Oct 08 #Javascript
javascript学习笔记(六)数据类型和JSON格式
Oct 08 #Javascript
javascript学习笔记(五)原型和原型链详解
Oct 08 #Javascript
JavaScript中获取高度和宽度函数总结
Oct 08 #Javascript
5个可以帮你理解JavaScript核心闭包和作用域的小例子
Oct 08 #Javascript
JavaScript中获取样式的原生方法小结
Oct 08 #Javascript
吐槽一下我所了解的Node.js
Oct 08 #Javascript
You might like
一个连接两个不同MYSQL数据库的PHP程序
2006/10/09 PHP
在JavaScript中调用php程序
2009/03/09 PHP
php生成静态页面并实现预览功能
2019/06/27 PHP
JavaScript 编写匿名函数的几种方法
2010/02/21 Javascript
jQuery之end()和pushStack()使用介绍
2012/02/07 Javascript
jquery显示和隐藏div特效实例
2013/02/27 Javascript
解决IE6的PNG透明JS插件使用介绍
2013/04/17 Javascript
JavaScript匿名函数用法分析
2015/02/13 Javascript
jQuery源码解读之removeClass()方法分析
2015/02/20 Javascript
js操作数组函数实例小结
2015/12/10 Javascript
Node.js文件操作方法汇总
2016/03/22 Javascript
JavaScript实现显示函数调用堆栈的方法
2016/04/21 Javascript
基于jquery实现即时检查格式是否正确的表单
2016/05/06 Javascript
jquery判断checkbox是否选中及改变checkbox状态的实现方法
2016/05/26 Javascript
基于vue2框架的机器人自动回复mini-project实例代码
2017/06/13 Javascript
mint-ui的search组件在键盘显示搜索按钮的实现方法
2017/10/27 Javascript
layUI实现列表查询功能
2019/07/27 Javascript
部署vue+Springboot前后端分离项目的步骤实现
2020/05/31 Javascript
解决vue项目input输入框双向绑定数据不实时生效问题
2020/08/05 Javascript
MySQL最常见的操作语句小结
2015/05/07 Python
Python输出9*9乘法表的方法
2015/05/25 Python
基于Python Shell获取hostname和fqdn释疑
2016/01/25 Python
python xml解析实例详解
2016/11/14 Python
windows系统下Python环境搭建教程
2017/03/28 Python
python生成tensorflow输入输出的图像格式的方法
2018/02/12 Python
python可视化实现KNN算法
2019/10/16 Python
python调用Matplotlib绘制分布点图
2019/10/18 Python
python文字转语音的实例代码分析
2019/11/12 Python
关于django python manage.py startapp 应用名出错异常原因解析
2020/12/15 Python
2014年大班元旦活动方案
2014/02/26 职场文书
试用期自我鉴定范文
2014/03/20 职场文书
项目投资合作意向书
2014/07/29 职场文书
2014学校领导四风对照检查材料思想汇报
2014/09/23 职场文书
教师继续教育反思周记
2015/06/25 职场文书
Java中生成微信小程序太阳码的实现方案
2022/06/01 Java/Android
CSS中calc(100%-100px)不加空格不生效
2023/05/07 HTML / CSS