正则表达式

目录

语法

元字符

限定符

边界符

特殊符号

标示符

正则表达式的方法

字符串方法 - 搭配正则表达式使用

常见的正则表达式


语法

// 字面量创建
var reg = /abcdefg/i

//构造函数创建
var reg=new RegExp(pattern, attributes);
pattern 为一个字符串或匹配规则
attributes 为可选字符串,包含属性g、i 和 m

元字符

. : 匹配非换行的任意字符
\ : 转译符号,把有意义的 符号 转换成没有意义的 字符,把没有意义的 字符 转换成有意义的 符号
\s : 匹配空白字符(空格/制表符/...)
\S : 匹配非空白字符
\d : 匹配数字
\D : 匹配非数字
\w : 匹配数字字母下划线
\W : 匹配非数字字母下划线

限定符

* : 前一个内容重复至少 0 次,也就是可以出现 0 ~ 正无穷
+ : 前一个内容重复至少 1 次,也就是可以出现 1 ~ 正无穷
? : 前一个内容重复 0 或者 1 次,也就是可以出现 0 ~ 1
{n} : 前一个内容重复 n 次,也就是必须出现 n
{n,} : 前一个内容至少出现 n 次,也就是出现 n ~ 正无穷
{n,m} : 前一个内容至少出现 n 次至多出现 m 次,也就是出现 n ~ m

边界符

^ : 表示开头
$ : 表示结尾

特殊符号

() : 限定一组元素
[] : 字符集合,表示写在 [] 里面的任意一个都行
[^] : 反字符集合,表示写在 [^] 里面之外的任意一个都行
- : 范围,比如 a-z 表示从字母 a 到字母 z 都可以
| : 或,正则里面的或 a|b 表示字母 a 或者 b 都可以

标示符

i : 表示忽略大小写
这个 i 是写在正则的最后面的
/\w/i
就是在正则匹配的时候不去区分大小写
g : 表示全局匹配
这个 g 是写在正则的最后面的
/\w/g
就是全局匹配字母数字下划线
m :表示多行匹配
这个 m 是写在正则的最后面的
/\w/m
就是多行匹配字母数字下划线

正则表达式的方法

1、test - 是用来检测字符串是否符合我们正则的标准

语法: 正则.test(字符串) - 返回布尔值

console.log(/\d+/.test('123')) // true
console.log(/\d+/.test('abc')) // false

2、exec - 是把字符串中符合条件的内容以数组的方式捕获出来,找不到就返回null

语法: 正则.exec(字符串)

返回值: 把字符串中符合正则要求的第一项以及一些其他信息,以数组的形式返回
var reg = /\d{3}/
var str = 'hello123world456你好789'
var res = reg.exec(str)
console.log(res)
/*
    ["123", index: 5, input: "hello123world456你好789", groups: undefined]
    0: "123"
    groups: undefined
    index: 5
    input: "hello123world456你好789"
    length: 1
      __proto__: Array(0)
*/

3、compile - 该方法可以重编辑指定的正则表达式

var num='13520006789';
var reg=/^13[4-9]\d{8}$/g;
console.log(reg.test(num));
reg.compile(/^13[0-3][0-9]{8}$/,'g');//修改正则
console.log(reg.test(num));//false

字符串方法 - 搭配正则表达式使用

1、search - 是查找字符串中是否有满足正则条件的内容

语法: 字符串.search(正则)

var reg = /\d{3}/
var str = 'hello123'
var str2 = 'hello'
console.log(str.search(reg)) // 5
console.log(str2.search(reg)) // -1

2、match - 找到字符串中符合正则条件的内容返回

语法: 字符串.match(正则)

返回值 :

  • 没有标示符 g 的时候,是和 exec 方法一样,返回一个数组
  • 有标示符 g 的时候,是返回一个数组,里面是匹配到的每一项
var reg = /\d{3}/
var str = 'hello123world456'
var str2 = 'hello'
console.log(str.match(reg)) 
// ["123", index: 5, input: "hello123wor456", groups: undefined]
console.log(str2.match(reg)) // null
var reg = /\d{3}/g
var str = 'hello123world456'
var str2 = 'hello'
console.log(str.match(reg)) 
// ["123", "456"]
console.log(str2.match(reg)) // null

3、replace - 是将字符串中满足正则条件的字符串替换掉

语法: 字符串.replace(正则,要替换的字符串)

返回值 : 替换后的字符串

var reg = /\d{3}/
var str = 'hello123world456'
var str2 = 'hello'
console.log(str.replace(reg,'666')) // hello666world456
console.log(str2.replace(reg)) // hello
var reg = /\d{3}/g
var str = 'hello123world456'
var str2 = 'hello'
console.log(str.replace(reg,'666')) // hello666world666
console.log(str2.replace(reg)) // hello

常见的正则表达式

过滤HTML标签
尖括号里是除了尖括号之外其他字符  /<[^<>]+>/g

匹配邮政编码
开头非0的6位数字  /^[1-9]\d{5}$/

文件格式检测
文件格式结尾为 .格式   
/\.(png|jpe?g|gif)$/    
/\.(mp4|webm|ogg|mp3|wav)$/

手机号
/^(1|\+861)[3-8]{1}\d{9}$/

身份证
身份证号码为15位或者18位,15位为全数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X 
/(^\d{15}$)|(^\d{17}(\d|X|x)$)/

中文检测
/[\u4e00-\u9fa5]+/g

QQ号验证  
/^[1-9]\d{4,10}$/

座机号码
010-86123456-2345
023-67622000-02
0755-66608483
开头为0,后面是2或三位数字加上 - 开头为非零的八位数字,结尾是 - 加1到4位数字的分机号
(0\d{2,3}-)?[1-9]\d{7,8}(-\d{1,4})?

邮箱格式
简单验证  /^\w+@[a-z0-9]+\.[a-z]+$/
具体验证  /^\w{2,18}@[0-9a-z]{1,10}(\.[a-z]{2,3}){1,2}$/

删除多余空格  
 str.replace(/\s+/,'');

删除首尾空格
str.replace(/^\s+/,'');
str.replace(/\s+$/,'');
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值