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正则学习笔记的更多相关文章

  1. javascript正则表达式 - 学习笔记

    JavaScript 正则表达式 学习笔记 标签(空格分隔): 基础 JavaScript 正则表达式是用于匹配字符串中字符组合的模式.在javascript中,正则表达式也是对象.这些模式被用于Re ...

  2. JavaScript正则表达式学习笔记(二) - 打怪升级

    本文接上篇,基础部分相对薄弱的同学请移步<JavaScript正则表达式学习笔记(一) - 理论基础>.上文介绍了8种JavaScript正则表达式的属性,本文还会追加介绍几种JavaSc ...

  3. JavaScript简易学习笔记

    学习地址:http://www.w3school.com.cn/js/index.asp 文字版: https://github.com/songzhenhua/github/blob/master/ ...

  4. javaScript 对象学习笔记

    javaScript 对象学习笔记 关于对象,这对我们软件工程到学生来说是不陌生的. 因为这个内容是在过年学到,事儿多,断断续续,总感觉有一丝不顺畅,但总结还是要写一下的 JavaScript 对象 ...

  5. 【MarkMark学习笔记学习笔记】javascript/js 学习笔记

    1.0, 概述.JavaScript是ECMAScript的实现之一 2.0,在HTML中使用JavaScript. 2.1 3.0,基本概念 3.1,ECMAScript中的一切(变量,函数名,操作 ...

  6. Javascript MVC 学习笔记(一) 模型和数据

    写在前面 近期在看<MVC的Javascript富应用开发>一书.本来是抱着一口气读完的想法去看的.结果才看了一点就傻眼了:太多不懂的地方了. 仅仅好看一点查一点,一点一点往下看吧,进度虽 ...

  7. Javascript作用域学习笔记(三)

    看完<你不知道的javascript>上,对作用域的新的理解(2018-9-25更) 一.学习笔记:   1.javascript中的作用域和作用域链 +  每个函数在被调用时都会创建一个 ...

  8. Javascript - Promise学习笔记

    最近工作轻松了点,想起了以前总是看到的一个单词promise,于是耐心下来学习了一下.   一:Promise是什么?为什么会有这个东西? 首先说明,Promise是为了解决javascript异步编 ...

  9. JavaScript闭包学习笔记

    此文都是大牛们关于闭包的观点,在此只是总结. 闭包应用的两种情况即可——函数作为返回值,函数作为参数传递. 1 深入理解javascript原型和闭包 判断一个变量是不是对象非常简单.值类型的类型判断 ...

随机推荐

  1. mac保存远程链接

    安装sshpass,前提是已经安装好iterm2 下载地址:http://sourceforge.net/projects/sshpass/files/ 百度网盘:https://pan.baidu. ...

  2. Excel中外部数据链接无法删除的解决方法【转】

    [摘要] 当Excel中公式引用了外部数据,每次打开时,总是自动弹出自动更新链接的对话框.如何找到这些链接?有没有办法实现断开原有链接,而保持数值不变? 有客户反应,当Excel无法链接到外部数据后, ...

  3. 4.QOpenGLWidget-对三角形进行纹理贴图、纹理叠加

    在上章3.QOpenGLWidget-通过着色器来渲染渐变三角形,我们为每个顶点添加颜色来增加图形的细节,从而创建出有趣的图像.但是,如果想让图形看起来更真实,我们就必须有足够多的顶点,从而指定足够多 ...

  4. 1.opengl绘制三角形

    顶点数组对象:Vertex Array Object,VAO,用于存储顶点状态配置信息,每当界面刷新时,则通过VAO进行绘制. 顶点缓冲对象:Vertex Buffer Object,VBO,通过VB ...

  5. Helium文档4-WebUI自动化-write写入

    前言 write方法是模拟在输入框中写入数据 write入参说明 def write(text, into=None):   """   :param text: The ...

  6. 5G-第五代移动通信系统(5th generation mobile/wireless/cellular system)

    通信系统 有意义的信息交流被称为通讯. 自然界:狼嚎.狗叫.虫鸣.鸡叫. 人类社会:说话.眼神.写信.烽火台. 目的:信息的传递. 人类发明电以后,开始使用电来传递信息,特别快. 于是有了电报.电话以 ...

  7. java面试之手写单例模式

    为什么要有单例模式 实际编程应用场景中,有一些对象其实我们只需要一个,比如线程池对象.缓存.系统全局配置对象等.这样可以就保证一个在全局使用的类不被频繁地创建与销毁,节省系统资源. 实现单例模式的几个 ...

  8. Jupyter Notebook使用教程

    关于安装我就不说了,可以参考知乎https://zhuanlan.zhihu.com/p/33105153(总结的很全面) 首先打开Jupyter Notebook后,新建notebook:点击右上角 ...

  9. JUC---06线程间通信(二)

    二.线程间定制化调用通信 要使多线程之间按顺序调用,实现A->B->C按顺序输出,使用Lock锁实现,通过Lock锁创建三个Condition实例(三把钥匙),通过不同的条件,调用不同钥匙 ...

  10. web worker的介绍和使用

    目录 简介 Web Workers的基本概念和使用 Web Workers的分类 worker和main thread之间的数据传输 简介 什么是web worker呢?从名字上就可以看出,web w ...