JavaScript正则学习笔记
RegExp
元字符
' . ' 点号:匹配任意的字符
^ $ 位置字符
- ^ 匹配字符串开始的位置
- $ 匹配字符串结束的位置
匹配数字和非数字 \d 和 \D
匹配空白字符 \s 和 \S
- \s 匹配空白字符
- \S 匹配非空白字符
中文 unicode 码 的区间 [\u4e00-\u9fa5]
[] 匹配里面的任意字符
[^a-z] 匹配除a到z之外的所有字符
`+` 匹配一次或者 多次 (所约束的条件必须存在,不然无法匹配)
var reg = /[mM][jJ]+/g
//可以这样写
var reg = /[m][j]+/gi
// 是匹配的时候不区分大小写
`*` 匹配 0 次或者 多次 (真正意义 上的可有可无)
- 加号和星号的区别
`?` 匹配重复的一次或者是零次 ( 所受约束的条件可有至多为一次,可无为零次)
原子组 ()
- 捕获的方法: RegExp.$1 $2 $3
- 有多少个组,就可以使用$num来获取第几组所匹配的字符串
| 或者
`?:` 分组匹配不捕获
正向预查
?= 无正向肯定预查 表示肯定是元 ,但不匹配
- ?! 元 正向否定预查 表示肯定不是元,不匹配 **
!
? <= ¥ 反向肯定预查 表示肯定是¥ ,但不匹配**
?<! ¥ 反向否定 预查 表示肯定不是¥,不匹配**
重复类 /[\d]{0,12}/g 大括号内表示的是所匹配的的长度,(也就是所匹配的字符的重复次数)
正则实例对象的方法
test()
- 返回一个布尔值,表示当前模式是否能匹配参数字符串
reg.exec(str)
- 用来返回匹配的结果,如果发现匹配,就返回一个数组,数组中的成员都是匹配的子字符串,否则返回null
字符串方法
- match()
- 对字符串进行正则匹配,返回匹配的结果
- search()
- 返回第一个满足条件的匹配结果在整个字符串中的位置,如果没有任何匹配,则返回-1
- replace()
- 可以替换匹配的值,它接受两个参数,第一个是正则表达式,表示搜索模式,第二个是替换的内容
验证用户账号
验证手机号码
function checkPhone(phone){
var reg = /^1[3|5|6|7|8|9|]\d{9}$/g;
if(reg.test(phone)){
console.log(`此 ${phone} 手机号码格式正确`)
}else{
console.log(`此 ${phone} 手机号码格式错误`)
}
}
console.log('手机号码验证')
checkPhone('12312312312')
checkPhone('16677777 ')
checkPhone('166777770000')
checkPhone('17775646924')
console.log('\n\n座机号码验证')
function checkTelPhone(phone){
var reg = /^0\d{2,3}-?\d{7,8}/g;
if(reg.test(phone)){
console.log(`此 ${phone} 座机号码格式正确`)
}else{
console.log(`此 ${phone} 座机号码格式错误`)
}
}
checkTelPhone("0108888888")
checkTelPhone("01088888889")
checkTelPhone("0108-8888889")
checkTelPhone("01088-888889")
checkTelPhone("1088-888889")
checkTelPhone("088-8888811")
checkTelPhone("088-888889")
// 匹配身份证号
// 18 位或者15位,15位全是数字 18位 前17都是数字,最后一位可能是数字或者字符x或X
function checkId(id){
var reg = /(^\d{15}$)|(^\d{17}[x|\d]$)/gi;
console.log(reg.test(id)? "正确":"错误");
}
checkId('123456789012345678')
checkId('12345678901234567x')
checkId('12345678901234567X')
checkId('123456789012345')
console.log("---------")
checkId('12345678901234')
checkId('1234567890123456789')
checkId('12345678901234567a')
//匹配邮箱
// 第一部分@ 第二部分 .com | cn | net
function checkEmail(email){
var reg = /^\w+@\w+\.(com|cn|net|cc)$/gi;
console.log(reg.test(email) ? "邮箱格式正确":"邮箱格式错误");
}
checkEmail("pphboy@qq.com")
checkEmail("pphboy@123.com")
checkEmail("pphboy@123com")
checkEmail("pphboy123.com")
JavaScript正则学习笔记的更多相关文章
- javascript正则表达式 - 学习笔记
JavaScript 正则表达式 学习笔记 标签(空格分隔): 基础 JavaScript 正则表达式是用于匹配字符串中字符组合的模式.在javascript中,正则表达式也是对象.这些模式被用于Re ...
- JavaScript正则表达式学习笔记(二) - 打怪升级
本文接上篇,基础部分相对薄弱的同学请移步<JavaScript正则表达式学习笔记(一) - 理论基础>.上文介绍了8种JavaScript正则表达式的属性,本文还会追加介绍几种JavaSc ...
- JavaScript简易学习笔记
学习地址:http://www.w3school.com.cn/js/index.asp 文字版: https://github.com/songzhenhua/github/blob/master/ ...
- javaScript 对象学习笔记
javaScript 对象学习笔记 关于对象,这对我们软件工程到学生来说是不陌生的. 因为这个内容是在过年学到,事儿多,断断续续,总感觉有一丝不顺畅,但总结还是要写一下的 JavaScript 对象 ...
- 【MarkMark学习笔记学习笔记】javascript/js 学习笔记
1.0, 概述.JavaScript是ECMAScript的实现之一 2.0,在HTML中使用JavaScript. 2.1 3.0,基本概念 3.1,ECMAScript中的一切(变量,函数名,操作 ...
- Javascript MVC 学习笔记(一) 模型和数据
写在前面 近期在看<MVC的Javascript富应用开发>一书.本来是抱着一口气读完的想法去看的.结果才看了一点就傻眼了:太多不懂的地方了. 仅仅好看一点查一点,一点一点往下看吧,进度虽 ...
- Javascript作用域学习笔记(三)
看完<你不知道的javascript>上,对作用域的新的理解(2018-9-25更) 一.学习笔记: 1.javascript中的作用域和作用域链 + 每个函数在被调用时都会创建一个 ...
- Javascript - Promise学习笔记
最近工作轻松了点,想起了以前总是看到的一个单词promise,于是耐心下来学习了一下. 一:Promise是什么?为什么会有这个东西? 首先说明,Promise是为了解决javascript异步编 ...
- JavaScript闭包学习笔记
此文都是大牛们关于闭包的观点,在此只是总结. 闭包应用的两种情况即可——函数作为返回值,函数作为参数传递. 1 深入理解javascript原型和闭包 判断一个变量是不是对象非常简单.值类型的类型判断 ...
随机推荐
- mac保存远程链接
安装sshpass,前提是已经安装好iterm2 下载地址:http://sourceforge.net/projects/sshpass/files/ 百度网盘:https://pan.baidu. ...
- Excel中外部数据链接无法删除的解决方法【转】
[摘要] 当Excel中公式引用了外部数据,每次打开时,总是自动弹出自动更新链接的对话框.如何找到这些链接?有没有办法实现断开原有链接,而保持数值不变? 有客户反应,当Excel无法链接到外部数据后, ...
- 4.QOpenGLWidget-对三角形进行纹理贴图、纹理叠加
在上章3.QOpenGLWidget-通过着色器来渲染渐变三角形,我们为每个顶点添加颜色来增加图形的细节,从而创建出有趣的图像.但是,如果想让图形看起来更真实,我们就必须有足够多的顶点,从而指定足够多 ...
- 1.opengl绘制三角形
顶点数组对象:Vertex Array Object,VAO,用于存储顶点状态配置信息,每当界面刷新时,则通过VAO进行绘制. 顶点缓冲对象:Vertex Buffer Object,VBO,通过VB ...
- Helium文档4-WebUI自动化-write写入
前言 write方法是模拟在输入框中写入数据 write入参说明 def write(text, into=None): """ :param text: The ...
- 5G-第五代移动通信系统(5th generation mobile/wireless/cellular system)
通信系统 有意义的信息交流被称为通讯. 自然界:狼嚎.狗叫.虫鸣.鸡叫. 人类社会:说话.眼神.写信.烽火台. 目的:信息的传递. 人类发明电以后,开始使用电来传递信息,特别快. 于是有了电报.电话以 ...
- java面试之手写单例模式
为什么要有单例模式 实际编程应用场景中,有一些对象其实我们只需要一个,比如线程池对象.缓存.系统全局配置对象等.这样可以就保证一个在全局使用的类不被频繁地创建与销毁,节省系统资源. 实现单例模式的几个 ...
- Jupyter Notebook使用教程
关于安装我就不说了,可以参考知乎https://zhuanlan.zhihu.com/p/33105153(总结的很全面) 首先打开Jupyter Notebook后,新建notebook:点击右上角 ...
- JUC---06线程间通信(二)
二.线程间定制化调用通信 要使多线程之间按顺序调用,实现A->B->C按顺序输出,使用Lock锁实现,通过Lock锁创建三个Condition实例(三把钥匙),通过不同的条件,调用不同钥匙 ...
- web worker的介绍和使用
目录 简介 Web Workers的基本概念和使用 Web Workers的分类 worker和main thread之间的数据传输 简介 什么是web worker呢?从名字上就可以看出,web w ...