这篇文章将为大家详细讲解有关正则表达式regex有什么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
正则表达式,又称正规表示式、正规表示法、正规表达式、规则表达式、常规表示法(英语:Regular Expression,在代码中常简写为regex、regexp或RE)。
正则表达式使用单个字符串来描述、匹配一系列符合某个句法规则的字符串。在很多文本编辑器里,正则表达式通常被用来检索、替换那些符合某个模式的文本。
一、字符类
1、字符类:可以匹配他所包含的任意字符
eg:/[abc]/和字母"a"、"b"、"c"中的任意一个匹配
2、否定字符类: 通过"^"字符定义否定字符类,他匹配所有不包含在方括号内的字符。定义否定字符类时,将一个"^"符号作为左括号内的第一个字符。
eg:/[^abc]/匹配"a"、"b"、"c"之外的所有字符。
3、\s : 匹配的是空格符、制表符和其他Unicode空白符;
. : 除换行符和其他Unicode行终止符之外的任意字符。
二、重复:
1、{n,m} 匹配前一项至少n次,但不能超过m次;
2、{n,} 匹配前一项n次或者更多次;
3、{n} 匹配前一项n次;
4、? 匹配前一项0次或者1次;
5、* 匹配前一项0次或者多次;
6、+ 匹配前一项1次或者多次 .
PS:非贪婪性重复---在待匹配的字符后面跟随一个问号即可。 "??" "+?" "*?"
三、选择、分组和引用
1、"|" 分割供选择的字符
eg:/ab|cd|ef/ 可以匹配字符串"ab"、也可以匹配字符串"cd"、还可以匹配字符串"ef"
2、"()":圆括号的作用:a.把单独的项组合成子表达式;b.在完整的模式中定义子模式;c.允许在同一正则表达式的后部引用前面的子表达式。
3、"(?:" 和 ")"进行分组,但不记忆与改组相匹配的字符
四、指定匹配位置:
1、匹配发生的合理位置,正则表达式的锚。
2、"^" 匹配字符串的开始
3、"$" 匹配字符串的结束
4、任意正则表达式都可以作为锚点。如果在符号"(?="和")"之间加入一个表达式,它就是一个先行断言。
5、负先行断言"(?!"和")"
五、修饰符:
1、i 不区分大小写
2、g 全局匹配
3、m 多行中执行匹配
六、RegExp方法
------- String 方法 -------
1、search() 返回第一个与之匹配的字符串的位置;
2、repalce() 执行检索和替换操作
如果正则表达式设置了修饰符g,那么源字符串中所有与模式匹配的字符串都将替换成第二个参数指定的字符串;如果不带修饰符g,则只替换匹配的第一个子串。
3、match() 返回由匹配结果组成的数组
------- RegExp方法 -------
4、exec()
5、test()
======================= 一些常用的正则表达式 ========================
1、删除首尾行的空白字符(包括空格符、制表符、其他Unicode空白符)
var pattern = /(^\s*)|(\s*$)/g ;
" abc def ".replace(pattern,""); //执行结果是:"abc def"
2、强密码:密码为8-12位,并且大写字母、小写字母、数字、特殊字符都包含
var strongRegExp = /^(?=.{8,12})(?=.*[A-Z])(?=.*[a-z])(?=.*[0-9])(?=.*\W).*$/g ;
3、弱密码:密码为7-12位,并且包含大写字母、小写字母、数字中任意两项,且不包含特殊字符
var mediumRegExp = /^(?=.{7,12})(((?=.*[A-Z])(?=.*[a-z]))|((?=.*[A-Z])(?=.*[1-9]))|((?=.*[a-z])(?=.*[1-9]))).*$/g ;
关于“正则表达式regex有什么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。