JS基础 - 正则笔记

一些概念

正则表达式(Regular Expression)是一种字符串匹配的模式(规则)

使用场景:

  • 例如验证表单:手机号表单要求用户只能输入11位的数字 (匹配)

  • 过滤掉页面内容中的一些敏感词(替换),或从字符串中获取我们想要的特定部分(提取)等

工具网站: https://tool.oschina.net/regex#

正则基本使用

  1. 定义规则

    复制代码
    const reg =  /表达式/
    • 其中/ /是正则表达式字面量

    • 正则表达式也是对象

  2. 使用正则

    • test()方法 用来查看正则表达式与指定的字符串是否匹配

      如果正则表达式与指定的字符串匹配 ,返回true,否则false

    • exec() 在一个指定字符串中执行一个搜索匹配,如果匹配成功,返回一个数组,否则返回null

复制代码
// 正则表达式的基本使用
const str = 'web前端开发'
// 1. 定义规则
const reg = /web/
​
// 2. 使用正则  test()
console.log(reg.test(str))  // true  如果符合规则匹配上则返回true
console.log(reg.test('java开发'))  // false  如果不符合规则匹配上则返回 false

元字符

  1. 普通字符:
  • 大多数的字符仅能够描述它们本身,这些字符称作普通字符,例如所有的字母和数字。

  • 普通字符只能够匹配字符串中与它们相同的字符。

  • 比如,规定用户只能输入英文26个英文字母,普通字符的话 /[abcdefghijklmnopqrstuvwxyz]/

  1. 元字符(特殊字符)
  • 是一些具有特殊含义的字符,可以极大提高了灵活性和强大的匹配功能。

  • 比如,规定用户只能输入英文26个英文字母,换成元字符写法: /[a-z]/

元字符分类:边界符、量词、字符类

边界符

正则表达式中的边界符(位置符)用来提示字符所处的位置,主要有两个字符

如果 ^ 和 $ 在一起,表示必须是精确匹配

复制代码
// 元字符之边界符
// 1. 匹配开头的位置 ^
const reg = /^web/
console.log(reg.test('web前端'))  // true
console.log(reg.test('前端web'))  // false
console.log(reg.test('前端web学习'))  // false
console.log(reg.test('we'))  // false
​
// 2. 匹配结束的位置 $
const reg1 = /web$/
console.log(reg1.test('web前端'))  //  false
console.log(reg1.test('前端web'))  // true
console.log(reg1.test('前端web学习'))  // false
console.log(reg1.test('we'))  // false  
​
// 3. 精确匹配 ^ $
const reg2 = /^web$/
console.log(reg2.test('web前端'))  //  false
console.log(reg2.test('前端web'))  // false
console.log(reg2.test('前端web学习'))  // false
console.log(reg2.test('we'))  // false 
console.log(reg2.test('web'))  // true
console.log(reg2.test('webweb'))  // flase 
量词

量词用来设定某个模式重复次数

复制代码
// 元字符之量词
// 1. * 重复次数 >= 0 次
const reg1 = /^w*$/
console.log(reg1.test(''))  // true
console.log(reg1.test('w'))  // true
console.log(reg1.test('ww'))  // true
console.log('-----------------------')
​
// 2. + 重复次数 >= 1 次
const reg2 = /^w+$/
console.log(reg2.test(''))  // false
console.log(reg2.test('w'))  // true
console.log(reg2.test('ww'))  // true
console.log('-----------------------')
​
// 3. ? 重复次数  0 || 1 
const reg3 = /^w?$/
console.log(reg3.test(''))  // true
console.log(reg3.test('w'))  // true
console.log(reg3.test('ww'))  // false
console.log('-----------------------')
​
​
// 4. {n} 重复 n 次
const reg4 = /^w{3}$/
console.log(reg4.test(''))  // false
console.log(reg4.test('w'))  // flase
console.log(reg4.test('ww'))  // false
console.log(reg4.test('www'))  // true
console.log(reg4.test('wwww'))  // false
console.log('-----------------------')
​
// 5. {n,} 重复次数 >= n 
const reg5 = /^w{2,}$/
console.log(reg5.test(''))  // false
console.log(reg5.test('w'))  // false
console.log(reg5.test('ww'))  // true
console.log(reg5.test('www'))  // true
console.log('-----------------------')
​
// 6. {n,m}   n =< 重复次数 <= m
const reg6 = /^w{2,4}$/
console.log(reg6.test('w'))  // false
console.log(reg6.test('ww'))  // true
console.log(reg6.test('www'))  // true
console.log(reg6.test('wwww'))  // true
console.log(reg6.test('wwwww'))  // false
​
// 7. 注意事项: 逗号两侧千万不要加空格否则会匹配失败
字符类

某些常见模式的简写方式,区分字母和数字

  1. \] 匹配字符集合 后面的字符串只要包含 abc 中任意**一个字符**,都返回 true 。

    使用连字符 - 表示一个范围

    比如:

    a-z\] 表示 a 到 z 26个英文字母都可以 \[a-zA-Z\] 表示大小写都可以 \[0-9\] 表示 0\~9 的数字都可以

    注意要写到中括号里面

  2. 点 . 匹配除换行符之外的任何单个字符

复制代码
​
// 元字符之范围  []  
// 1. [abc] 匹配包含的单个字符, 多选1
const reg1 = /^[abc]$/
console.log(reg1.test('a'))  // true
console.log(reg1.test('b'))  // true
console.log(reg1.test('c'))  // true
console.log(reg1.test('d'))  // false
console.log(reg1.test('ab'))  // false
​
// 2. [a-z] 连字符 单个
const reg2 = /^[a-z]$/
console.log(reg2.test('a'))  // true
console.log(reg2.test('p'))  // true
console.log(reg2.test('0'))  // false
console.log(reg2.test('A'))  // false
// 想要包含小写字母,大写字母 ,数字
const reg3 = /^[a-zA-Z0-9]$/
console.log(reg3.test('B'))  // true
console.log(reg3.test('b'))  // true
console.log(reg3.test(9))  // true
console.log(reg3.test(','))  // flase
​
// 用户名可以输入英文字母,数字,可以加下划线,要求 6~16位
const reg4 = /^[a-zA-Z0-9_]{6,16}$/
console.log(reg4.test('abcd1'))  // false 
console.log(reg4.test('abcd12'))  // true
console.log(reg4.test('ABcd12'))  // true
console.log(reg4.test('ABcd12_'))  // true
​
// 3. [^a-z] 取反符
const reg5 = /^[^a-z]$/
console.log(reg5.test('a'))  // false 
console.log(reg5.test('A'))  // true
console.log(reg5.test(8))  // true
​

替换和修饰符

replace 替换方法,可以完成字符的替换

复制代码
// 替换和修饰符
const str = '欢迎大家学习前端,相信大家一定能学好前端,都成为前端大神'
// 1. 替换  replace  需求:把前端替换为 web
// 1.1 replace 返回值是替换完毕的字符串
// const strEnd = str.replace(/前端/, 'web') 只能替换一个

修饰符约束正则执行的某些细节行为,如是否区分大小写、是否支持多行匹配等

  • i 是单词 ignore 的缩写,正则匹配时字母不区分大小写

  • g 是单词 global 的缩写,匹配所有满足正则表达式的结果

复制代码
// 替换和修饰符
const str = '欢迎大家学习前端,相信大家一定能学好前端,都成为前端大神'
// 修饰符 g 全部替换
const strEnd = str.replace(/前端/g, 'web')
console.log(strEnd) 
相关推荐
لا معنى له1 小时前
残差网络论文学习笔记:Deep Residual Learning for Image Recognition全文翻译
网络·人工智能·笔记·深度学习·学习·机器学习
专注前端30年1 小时前
如何使用 HTML5 的 Canvas + JavaScript 实现炫酷的游戏得分特效?
前端·javascript·游戏·html5·canvas·canva可画
xxp43211 小时前
Qt 网络编程 TCP通信
开发语言·qt
T***u3332 小时前
PHP在电商中的会员管理
开发语言·wireshark·php·ue4·jina
张丶大帅2 小时前
JS案例合集
开发语言·javascript·笔记
2301_795167203 小时前
Python 高手编程系列八:缓存
开发语言·python·缓存
helloyangkl3 小时前
前端——不同环境下配置env
前端·javascript·react.js
8***29313 小时前
Go基础之环境搭建
开发语言·后端·golang
Yue丶越3 小时前
【C语言】自定义类型:联合体与枚举
c语言·开发语言