正则相关的知识分享

正则:

概念:描述或匹配一系列符合某种规则的字符串

作用:数据验证 内容检索 内容替换 内容过滤

//创建正则对象 //通过实例化对象 letreg=newRegExp("正则表达式"+变量,"模式修正符") 模式修正符:g:global全局(下一次执行从上一次之后位置) i:不区分大小写m:可以换行 //通过字面量的方式 letreg=/ 正则表达式 /模式修正符 /为定界符正则对象的常用方法:

reg.test(str) 检测正则对象是否能够匹配str 返回true false

reg.exec(str) 检测正则对象是否能够匹配str 如果能匹配返回一个拥有特殊属性的数组,如果不能匹配返回null

正则表达式:

使用场景:1.正则对象 2.str.split(正则对象) 3.str.replace(正则对象,被替换的内容) 4.str.search(正则对象)

原子:正则表达式中最小的内容

\d 0-9

\w 数字字母下划线

\s 空白,\n,\r,\t

\D 除了0-9以外的字符

\W 除了数字字母下划线以外的字符

\S 除了空白,\n,\r,\t

原子表:[ ]

letreg=/[a-z]/g匹配小写字母 letreg=/[a-zA-Z]/g匹配所有字母

元字符:

. 所有的字符

| 或

原子组:() 原子组的内容会默认存储在内存中,在后面如果一模一样可以\1调用

letreg=/(山|陕)西/g letreg=/<div>box<\/div>/===letreg=/<(div)>box<\/\1>/ // \为转译字符 (?:xxx)不将xxx存储到内存中,并且不可调用

正则中的数量:

*:0个或多个

letreg=/\d*/g

+:1个或多个

?:0个或1个

{11}:11个 {15,18}:15到18个 {6,}六个或六个以上个

贪婪吝啬: *? 加问号将尽可能取多变成尽可能少取

边界判断:

^开始 $结束

letreg=/^\d{7}$/

\b 单词边界

\B 非单词边界

模式修正符:

g全局

i不区分大小写

m换行,多行

举例:

//正则汉字字母数字下划线返回bool

function isNotEmpty(str) {

var regex =newRegExp("^([\u4E00-\uFA29]|[\uE7C7-\uE7F3]|[a-zA-Z]|[0-9]|[_]){1,10}$");

return regex.test(str);

}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券