JS正则表达式入门篇

兰翠 就职于爱屋吉屋,出身后端现混迹于前端

正则表达式,又称规则表达式。(英语:Regular Expression,在代码中常简写为regex、regexp或RE),计算机科学的一个概念。正则表通常被用来检索、替换那些符合某个模式(规则)的文本,即只对字符串操作。

基本写法:

var reg = /a/;var reg = new RegExp('a');    //当正则需要传参,则只能用 new RegExp(paramName);正则默认匹配规则:正则匹配成功就会结束,不会继续匹配//i: 不区分大小写写法:var reg = /B/i,  var reg = new RegExp('B', 'i')//g: 全局匹配,写法:var reg = /B/g,  var reg = new RegExp('B', 'g')

正则表达式常用方法:

test: 正则去匹配字符串,如果匹配成功就返回真,失败就返回假   写法: reg.test(str)    eg: /\d/g.test('123')   // true
search: 正则去匹配字符串,如果匹配成功,就返回匹配成功的位置,如果匹配失败就返回-1  写法: str.search(reg)    eg: 'abcdef'.search(/c/)   // 2
match: 正则去匹配字符串,如果匹配成功,就返回匹配成功的数组,如果匹配不成功,就返回null  写法: str.match(reg)   eg: 'ab1cd12ddf456df'.match(/\d/g)  // 返回: [1, 12, 456]  注意: 当match不加g的时候,可以获取到子项的集合   eg: 'abc'.match(/(a)(b)(c)/)        // 返回:[abc, a, b, c]
replace: 正则去匹配字符串,匹配成功的字符去替换成新的字符串   写法: str.replace(reg, replace) // replace:第二个参数,可以是字符串,也可以是一个回调函数   eg:    str.replace(reg, 'aa')   eg:    var str = '2017-01-12'    var reg = /(/d)(-)/g    str.replace(reg, function($0, $1, $2) {        // 第一个参数:$0(母亲),        // 第二个参数:$1(第一个孩子),        // 第三个参数:$2(第二个孩子)        console.log($0);  // 2017-        console.log($1);  // 2017        console.log($2);  // -    })

正则表达式语法:

转义字符:.(点)---任意字符\.: 真正的点\s: 任何不可见字符,包括空格、制表符、换页符等等。等价于[ \f\n\r\t\v]。\S: 非不可见字符\d: 数字\D: 非数字\w: 字符 (字母,数字,下划线)\W: 非字符\b: 独立的部分(起始, 结束, 空格) // 'onetwo'.test(/\bone/)  —> true;   'onetwo'.test(/one\b/) —> false\B: 非独立的部分\1: 重复的子项  //\1重复的第一个子项,\2重复的第二个子项     eg:'abca'.test(/(a)bc\1/),  '<li></li>'.test(/<(\w)></\1>/)     eg:  查找重复字符串的字符和个数         var reg = /(\w)\1+/         var str = 'assssdfdbdsssdfdfsdssdsdssss'         var arr = str.split('').sort()         var index = 0, value=''         arr.replace(reg, function ($0, $1) {           if ($0.length > index) {              index = $0.length              value = $1           }        })
量词:匹配不确定的个数{a, b}: 最少出现a次,最多出现b次  {4,7}:<=4&&>=7,  {4,}:最少4次,{4}:正好4次+: 相当于{1,}, 至少出现一次>=1次?: 相当于{0, 1},0-1次*: 相当于{0,},至少出现0次^:正则的最开始位置,就代表起始的意思$:正则的最后位置,就代表结束的意思eg:匹配QQ号,5~12位,不能是0开头     var reg = /^[1,9]\d{4,-11}$/      '0123434aa'.test(reg)  —>falseeg: 替换字符串的前后空格      var reg = /^\s|\s$/     ' hello '.replace(reg, '')
匹配子项:(): 小括号,分组操作,    // 把正则的整体叫做(母亲)    // 然后把左边第一个小括号里的正则,叫做这个第一个子项(母亲的第一个孩子),第二个小括号就是第二个孩子[]: 一组相似的元素[abc], [a-z0-9],[^>]    // 'ab'.test(/[abc]/)|: 或者

原文发布于微信公众号 - 前端黑板报(FeHeiBanBao)

原文发表时间:2017-07-24

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Golang语言社区

举例讲解Go语言中函数的闭包使用

和变量的声明不同,Go语言不能在函数里声明另外一个函数。所以在Go的源文件里,函数声明都是出现在最外层的。 “声明”就是把一种类型的变量和一个名字联系起来。 G...

3285
来自专栏二进制文集

30分钟玩转「正则表达式」

推荐阅读:Jeffrey Friedl 《精通正则表达式(第3版)》,本文是该书的读书笔记。

1152
来自专栏Pythonista

golang之指针

接受者变量代表的值实际上是源值的复制品。如果这个值不是指针类型,在值方法中就没有途径去改变源值。

1053
来自专栏about云

spark开发基础之从Scala符号入门Scala

问题导读 1.Scala中有哪些常见符号? 2.本文讲了哪些符号? 3.你对符号的理解是什么? 4.<-,->,=>,Int=,_ 它们含义是什么?用在什么地...

3599
来自专栏林冠宏的技术文章

由 System.arraycopy 引发的巩固:对象引用 与 对象 的区别

首先明确一点,System.arraycopy 操作的是数组,效果是深复制。 是不是觉得怎么和你印象的中不一样? 重点来了,对于对象数组,例如: User[]...

1314
来自专栏C语言C++游戏编程

轻松学习C语言编程之函数知识详解

函数是一组一起执行任务的语句。每个C程序至少有一个函数,即main,所有最简单的程序都可以定义其他函数。您可以将代码划分为单独的函数。如何在不同的函数之间划分代...

1402
来自专栏程序员的知识天地

Python编程入门基础语法详解经典

sample_nest = [(2,4,6),{5:7,9:11,'key':[2,5]},6]

1001
来自专栏编程

浅谈Go语言中闭包的使用

闭包(Closure),又称词法闭包(Lexical Closure)或函数闭包(function closures),是引用了自由变量的函数。这个被引用的自由...

4428
来自专栏前端架构与工程

【译】《Understanding ECMAScript6》- 第二章-函数

函数在任何一门编程语言中都是很重要的一个环节。JavaScript至今已有多年的历史,但是它的函数仍然停留在很初级的阶段。函数问题的大量堆积,以及某些函数非常微...

2207
来自专栏信数据得永生

JavaScript 编程精解 中文第三版 九、正则表达式

3136

扫码关注云+社区

领取腾讯云代金券