在 JavaScript 中,正则表达式通常用于两个字符串方法 : search() 和 replace()。
search() 方法 用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串,并返回子串的起始位置。
replace() 方法 用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。
1.匹配模式
正则表达式查找与模式匹配的字符串部分
在JavaScript中,它们是在正斜杠之间//或使用new RegExp()
例如:
var str = "Visit Jb51.net!";
var n = str.search(/jb51.net/i);
例子2
<script language="javascript"> var reg=new RegExp("终古","g"); //创建正则RegExp对象 var stringObj="终古人民共和国,终古人民"; var newstr=stringObj.replace(reg,"中国"); alert(newstr); </script>
例子3
function dotag() { 第一种写法RegExp document.form1.tag.value = trim(document.form1.tag.value.replace(new RegExp(',',"gm"),',')); 第二种用// document.form1.tag.value = trim(document.form1.tag.value.replace(/,/gm,","); }
是不是第二中更好看,第一种遇到\w,还得多加一个\,\\w,所以一般情况下,我们都是用//.
更多的可以参考这篇文章:JavaScript replace new RegExp使用介绍
然后用于match , test或replace
您可以预先定义正则表达式,也可以直接在调用方法时定义
2.匹配多个
一次匹配单个字符,
或将多个字符放在方括号[]中以捕获任何匹配的字符
使用连字号捕获一系列字符-.
举例
[0-9]表示0,1,2...9的数字
[a-z]表示26个小写字母
[A-Z]表示26个大写字母
3.可选标志
在正则表达式的末尾添加可选标志,以修改匹配器的工作方式。
在JavaScript中,这些标志是:
i =不区分大小写 m =多行匹配 g =全局匹配(查找全部,而不是查找一个)
4.开始和结束
在开始处使用插入符号^表示“字符串开始”
在末尾使用美元符号$表示“字符串结尾”
开始将匹配项组合在一起以匹配更长的字符串
在表单验证中,需要前面加 ^后要加$
更多的可以参考这篇文章:https://www.jb51.net/article/118265.htm
5.通配符
使用通配符和特殊的转义字符来匹配较大类的字符
. =除换行符外的任何字符
\ d =数字 \ D =不是数字
\ s =空格 \ S =任何非空白
\ n新行 \w非空字母
6.特定数量
仅将特定数量的匹配字符或组与量词匹配
=零或更多 =还有一个? = 0或1 {3} =正好3倍{2,4} =两倍,三倍或四倍{2,} =两倍或更多倍
7.小括号匹配组
使用parens()捕获组
match会返回完整匹配加上组,除非您使用g标志
使用管道运算符| 在parens()内部以指定该组匹配的内容
| =或
8.反斜杠
要匹配特殊字符,请使用反斜杠\
JS正则表达式中的特殊字符是:^ $ \. * +? ()[] {} |
因此,要匹配一个星号,可以使用:
\ *
不只是*
9.中括号里的^
要匹配某个字符但要匹配某个字符,请在方括号内使用插入号^
这意味着^有两个含义,可能会造成混淆。
当它在正则表达式的前面时,它表示“字符串的开始”,而在方括号内使用时,则表示“不是此字符”。
10.总结
正则表达式可用于查找和匹配各种内容,从url到文件名
然而! 如果您尝试将正则表达式用于真正复杂的任务,请务必谨慎,例如解析电子邮件(这确实令人困惑,非常快)或HTML(非常规语言,因此无法由正则表达式完全解析)
正则表达式还有(当然)还有更多,例如懒惰vs贪婪,超前和捕获
更多的可以查看这篇文章:https://www.jb51.net/article/181099.htm
但是大多数web开发人员想要使用正则表达式的东西都可以仅使用这些基本构建块。
我已经在写一堆有关真实世界正则表达式用例的后续文章🎉
原文:https://dev.to/chrisachard/intro-to-regex-for-web-developers-2fj4
译文:http://caibaojian.com/10-regex-tip.html
小编特别补充,在这里推荐大家查看下面的文章。
正则表达式基础篇,正则基础
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]