当前位置:首页 > 技术分析 > 正文内容

10分钟快速掌握正则表达式

什么是正则表达式,英文名字 regular expression。其实说人话就是:

用有限的符号,表达无线的序列。

字面量创建正则表达式

let str = "jasonlee2023"
let x = "n"

//使用字面量形式,检测str字符串中是否有字符'x'
console.log(/x/.test(str))    //打印:false

//检测字符串str中是否有字符'n',在这里x是变量,代表'n'
console.log(eval(`/${x}/`).test(str))  //表示x变量

正则表达式的魅力

这里有一个邮箱地址,我想读取里面的数字,用JavaScript的split、filter、join等方法是可以实现的,如下:

let email = "jasonleeprogramer2023@126.com"

//1.传统方法
var result = email.split("").filter(item => {
  return !isNaN(item)
}).join("")
console.log(result)   //2023126

//2.传统方法
let arr = [...str]
result = arr.filter(item => !isNaN(item)).join("")
console.log(result)    //2023126

但是我们看到非常麻烦,如果有简便的方法,直接匹配数字不就可以了吗?这时候正则表达式就派上用场了。正则表达式可以用字面量的形式,也可以使用对象的形式。

//使用正则表达式
let email = "jasonleeprogramer2023@126.com"
// let reg = /\d/g       //1.使用字面量的形式
let reg = new RegExp(/\d/, "g")   //2.使用对象的形式
var result = email.match(reg).join("")
console.log(result)    //

解释:

  1. //表示正则表达式的边界符号
  2. \d表示的是数字
  3. g是global的简写,意思是全局匹配

原子组与原子表

中括号括起来的内容,就是原子表,比如 [abc]表示a、b、c中任何一个字母,都可以匹配成功。[a-z]表示任何一个小写英文字母都可以匹配成功。

如果你想匹配任何一个大写或小写英文字母,就得使用[a-zA-Z],如果你想匹配阿拉伯数字,就用[0-9]

//检测字符串"administrator"中是否有字符"a"
console.log(/[a]/.test("administrator"))  //打印:true

如果你想匹配连续的内容,比如想匹配abcxyz,那怎么办呢?这时候就用到了原子组。

小括号括起来的内容,就是原子组,表示一个整体

//表示匹配abc或xyz
let reg = /(abc|xyz)/
console.log( reg.test("abc") )   //打印:true
console.log(reg.test("ab"))     //打印:false,

下面比较一下原子表和原子组的区别:

原子表:只要满足其中一个,就匹配成功

let reg = /[123]/g        
let str = "18301627348"
let result = reg.test(str)    //检测是否满足条件
console.log(result)      //打印:true

原子组:需要满足整体,才匹配成功

let reg = /(123)/         //() 原子表:整体匹配
let str = "18301627348"
let result = reg.test(str)    //检测是否满足条件
console.log(result)     //打印:false,因为电话号码中没有连续的123

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/4575.html

标签: 正则 ?=
分享给朋友:

“10分钟快速掌握正则表达式” 的相关文章

基于archlinux的发行版有哪些?

Arch Linux 是一个 Linux 发行版,采用滚动更新的模型,这意味着 Arch Linux 不会定期发布新版本,而是持续接收更新和升级,保持系统与最新软件版本的同步。Arch Linux 以其极简主义、简单性和用户定制为中心的特点而闻名,专注于让用户对其系统配置具有完全控制权。然而,它也以...

Vue3 中有哪些值得深究的知识点?

众所周知,前端技术一直更新很快,这不 vue3 也问世这么久了,今天就来给大家分享下vue3中值得注意的知识点。喜欢的话建议收藏,点个关注!1、createAppvue2 和 vue3 在创建实例时,有很大的区别,具体对比如下://Vue 2 Vue.use({ router, store,...

用IDEA开发如何用Git快速拉取指定分支代码?

1,准备空的文件夹,git init2,关联远程仓库,git remote add origin gitlab地址3,拉取远程分支代码,git pull origin 远程分支名再用IDEA打开项目即可...

Acustica Audio 发布模拟Roland Jupiter 双声道合成器插件 TH2

福利: Acustica Audio 发布模拟Roland Jupiter 风格的双声道合成器插件 TH2 免费下载 意大利 Acustica Audio 公司发布布模拟Roland Jupiter 风格的双声道合成器插件 TH2 ,灵感来源于Acustica Audio的THING-8系列,它是...

「干货」FPGA设计中深度约束技巧及调试经验总结

今天跟大家分享的内容很重要,也是我们调试FPGA经验的总结。随着FPGA对时序和性能的要求越来越高,高频率、大位宽的设计越来越多。在调试这些FPGA样机时,需要从写代码时就要小心谨慎,否则写出来的代码可能无法满足时序要求。另外,最近跟网友聊天时,有谈到公众号寿命的问题,我觉得网络交换FPGA公众号应...

虚幻引擎5.5现已发布 手游开发、动画制作重大改进

Epic在今天发布了虚幻引擎5.5,现可通过Epic Launcher下载。此版本在动画创作、渲染、虚拟制片、移动端游戏开发和开发人员迭代工具集等方面做出了重大改进。 官方博客:虚幻引擎5.5现已发布,在动画创作、虚拟制作和移动游戏开发方面取得了显著进步,渲染、摄像机内视觉特效和开发人员迭代等领域的...