正则表达式用于对字符串模式匹配及检索替换,是对字符串执行模式匹配的强大工具。

 定义的方法:

  

var patt = new RegExp(pattern, modifiers) // var patt = new RegExp('x', 'i'), var patt = new RegExp(/x/i)
var patt = /pattern/modifiers; // var patt = /x/i

 常用的modifiers(修饰符):
  i - 修饰符是用来执行不区分大小写的匹配。
  g - 修饰符是用于执行全文的搜索(而不是在找到第一个就停止查找,而是找到所有的匹配)。
 方括号:

  

    [a-z] // 查找任何从小写 a 到小写 z 的字符。
[A-Z] // 查找任何从大写 A 到大写 Z 的字符。
[A-z] // 查找任何从大写 A 到小写 z 的字符。
[AB] // 查找方括号之间的任何字符。
[^AB] // 查找任何不在方括号之间的字符。
[0-9] // 查找任何从 0 至 9 的数字。

 元字符:

    \w // 查找数字、字母及下划线。
\W // 查找非单词字符。
\d // 查找数字。
\D // 查找非数字字符。
\s // 查找空白字符。
\S // 查找非空白字符。
\0 // 查找 NULL 字符。
\n // 查找换行符。
\r // 查找回车符。

 量词:

  

    n+ // 匹配任何包含至少一个 n 的字符串。
n* // 匹配任何包含零个或多个 n 的字符串。
n? // 匹配任何包含零个或一个 n 的字符串。
var str = "etestsstrrsessgsesx";
str.match(/es+/g) // es, ess, es (包含 e 并且至少包含一个 s)
str.match(/es*/g) // e, es, ess, es (包含 e 并且包含零个或多个 s)
str.match(/es?/g) // e, es, es, es (包含 e 并且至多包含一个 s)
n{X} // 匹配包含 X 个 n 的序列的字符串。
n{X,} // X 是一个正整数。前面的模式 n 连续出现至少 X 次时匹配。
n{X,Y} // X 和 Y 为正整数。前面的模式 n 连续出现至少 X 次,至多 Y 次时匹配。
n$ // 匹配任何结尾为 n 的字符串。
^n // 匹配任何开头为 n 的字符串。

 常用的方法:

    test() // 检测一个字符串是否匹配某个模式(RegExpObject.test(string))。返回 true 或 false。
exec() // 检索字符串中的正则表达式的匹配。如果字符串中有匹配的值返回该匹配值(数组结构),否则返回 null。
let testString = 'who are you'
let testStringMutil = 'who are you who are you'
let patt = new RegExp(/who/)
let patt0 = new RegExp(/who/g)
let patt1 = new RegExp(/^who$/g)
let patt2 = new RegExp(/whh/g)
patt.test(testString) // true
patt0.test(testString) // true
patt1.test(testString) // false
patt2.test(testString) // false
patt1.exec(testString) // null
patt2.exec(testString) // null
patt.exec(testStringMutil) // ['who'] (不带 g 只返回一个, 但是是第一个)
patt0.exec(testStringMutil) // ['who'] (带有 g 也只返回一个, 但是是最后一个)
string方法中支持正则的方法:
search() // 用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串。如果没有找到任何匹配的子串,则返回 -1, 找到即返回字符串的位置。
testStringMutil.search(patt) // 0 (不带 g , 返回第一个匹配的位置)
testStringMutil.search(patt0) // 0 (带有 g 也返回第一个匹配的位置)
match() // 在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。
testStringMutil.match(patt) // ['who'] (不带 g , 返回第一个匹配的)
testStringMutil.match(patt0) // ['who', 'who'] (带有 g 返回多个匹配的)

 常用的正则:

  

    手机号码: '^[1](([3][0-9])|([4][5-9])|([5][0-3,5-9])|([6][5,6])|([7][0-8])|([8][0-9])|([9][1,8,9]))[0-9]{8}$'
身份证号: '(^[1-9][0-9]{5}(18|19|20)[0-9]{2}((0[1-9])|(1[0-2]))(([0-2][1-9])|10|20|30|31)[0-9]{3}[0-9Xx]$)|(^[1-9][0-9]{5}[0-9]{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)[0-9]{2}$)'
电子邮箱: '^[A-Za-z0-9\u4e00-\u9fa5]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$'
中文: '^[\u4E00-\u9FA5]+$'

 

js基础学习-正则表达式的更多相关文章

  1. JS基础学习——对象

    JS基础学习--对象 什么是对象 对象object是JS的一种基本数据类型,除此之外还包括的基本数据类型有string.number.boolean.null.undefined.与其他数据类型不同的 ...

  2. JS基础学习——闭包

    JS基础学习--闭包 什么是闭包 闭包的定义如下,它的意思是闭包使得函数可以记住和访问它的词法范围,即使函数是在它声明的词法范围外执行.更简单来讲,函数为了自己能够正确执行,它对自己的词法范围产生闭包 ...

  3. JS基础学习——作用域

    JS基础学习--作用域 什么是作用域 变量的作用域就是变量能被访问到的代码范围,比如在下面的这个js代码中,变量a的作用域就是函数foo,因此在全局作用域内的console.log(a)语句不能访问到 ...

  4. JS 基础学习随想

    2012年就已经接触过了js,给我的印象:这是一门谈不上复杂的语言.大概这就是所谓的学的越浅,用的越少,觉得自己会的东西好像得更多吧!开始做基础练习题的时候觉得好像都十分简单.可是后来在做到对象数组的 ...

  5. handlebars.js基础学习笔记

    最近在帮学校做个课程网站,就有人推荐用jquery+ajax+handlebars做网站前端,刚接触发现挺高大上的,于是就把一些基础学习笔记记录下来啦. 1.引用文件: jquery.js文件下载:h ...

  6. JS基础学习1

    1 JS 概述 一个完整的javascript实现是由以下3个不同部分组成的: (1)     核心(ECMAscript) (2)     文档对象模型(DOM)  Document object ...

  7. JS基础学习篇(一)

    近来一直在学习js和jquery.刚刚进入前端工作还没有多久,虽然大学里学习的是编程自认为也学的还可以,但前端接触的不多,一直认为前端十分简单.其实不然,特别是工作的时候要自己设计一个完整的项目前端, ...

  8. Node.js基础学习四之注册功能

    前言:在Node.js学习(二)和(三)中介绍了如何在Node.js 中获取登录的用户名和密码与数据库进行验证并返回数据给客户端 需求:实现注册功能 为了区分登录和注册是两个不同的请求,在端口后面加上 ...

  9. 两万字Vue.js基础学习笔记

    Vue.js学习笔记 目录 Vue.js学习笔记 ES6语法 1.不一样的变量声明:const和let 2.模板字符串 3.箭头函数(Arrow Functions) 4. 函数的参数默认值 5.Sp ...

随机推荐

  1. NuGet包管理平台

    这节来讲一下.NET下的包管理平台:NuGet. 我们做一个项目,除了自己的代码文件之外,实际上还要引用诸多代码文件,这些文件可能是我们自己封装的底层框架代码,或者为了完成某个功能而引用的工具类文件等 ...

  2. 神器 Nginx 的学习手册 ( 建议收藏 )

    关注「开源Linux」,选择"设为星标" 回复「学习」,有我为您特别筛选的学习资料~ Nginx 是一个高性能的 HTTP 和反向代理服务器,特点是占用内存少,并发能力强,事实上 ...

  3. 用 Docker 快速搭建 Kafka 集群

    开源Linux 一个执着于技术的公众号 版本 •JDK 14•Zookeeper•Kafka 安装 Zookeeper 和 Kafka Kafka 依赖 Zookeeper,所以我们需要在安装 Kaf ...

  4. 为什么vue中的v-bind用在class属性上有点怪?

    如图所见,普通的标签属性我们直接使用 :属性名=`props的值` 就可以了.为什么用到class里要加[ ] 这个???

  5. 百度SEO算法技术的局限性,怎么做才能有收益

    不知道大家有没有发现,我们使用百度的频率在减少,就算有时遇到一些问题,需要用百度来寻找答案,也会经常遇到搜索不到答案的情况.到底是出了什么问题?难道网络上的资源不够丰富了?浩如烟海的互联网,居然搜索不 ...

  6. Windows IDEA Community 报错

    运行时报错 "CreateProcess error=206,文件名或扩展名太长" 解决方法:https://plugins.gradle.org/plugin/ua.eshepe ...

  7. Vue项目中的接口进阶使用

    创建services文件夹 1.文件夹apis.index.request的三个文件. 2.apis文件放接口 export const apis = { checkDeviceNo: '/api/c ...

  8. HashMap 中的 hash 函数

    1. 什么是 hash 函数 hash 函数,即散列函数,或叫哈希函数.它可以将不定长的输入,通过散列算法转换成一个定长的输出,这个输出就是散列值.需要注意的是,不同的输入通过散列函数,也可能会得到同 ...

  9. java面试:关于public static void main(String[] args)是什么意思?

    它是作为JAVA中的主函数,所有java程序的运行起点就是这个方法,除了args这个名字可以不一样外,其他必须是这样. 主函数的一般写法如下: public static void main(Stri ...

  10. JS基础6--逻辑运算符

     &&与  ||或   !非      如果对一个值进行两次取反,它不会变化      如果对一个非布尔值进行取反,则会将其转换为布尔值,再取反      所以我们可以利用该特点.来将 ...