正则RegExc
? ---恢复内容开始--- 什么是正则,正则就是一条规则,用于检验字符串的格式,目标就是字符串 正则的定义: 1、var reg=new? RegExp() 2、var ? reg=/格式/ 正则的方法有两个功能 1:test()用于匹配,匹配成功就是true,失败就是false 2:exec()用于捕获,有就拿出来 正则修饰符: 1、i:忽略大小写 2、g:代表全局匹配 3、M:代表多行匹配 ?? 用的最多的就是1和2 需要使用修饰符的写法: 1、var? reg=new? RegExp("hello",g) 2、 var ? reg=/hello/gi 跟正则有关的字符串的方法: 1、match()查找一个或多个与正则相匹配的,有就返回查找的结果,没有就是null
? ? 2、search()匹配和正则相同的字符,有就返回索引,没有就是-1
3、replace()匹配与正则相同的并替换掉,返回的替换后的字符串
? 正则的方括号: [abc]代表查找方括号中的任何字符 [^abc]代表查找任何一个不在方括号之间的字符 [0-9]查找0-9之间的数字 [a-z]查找任何小写a到小写z的字符 [A-Z]查找任何大写A到大写Z的字符 [A-z]查找大写A到小写z的字符 (red|blue|green)三者中的任意一个都行 元字符: .点代表单个字符 w代表单词字符 W代表非单词字符 d代表数字 D代表非数字 s代表空白字符 S代表非空白字符 b代表单词边界 B代表非单词边界 b代表数字 B代表非数字 量词: ? n+? 代表至少1个n的字符 ? n* ?? 代表0个或多个n ? n?? 包含0个或1个n ? N{x} ? 包含x个n N{x,}包含至少x个n ? N{x,y}? 包含大于等于x个小于等于y个n N$? 包含以n结尾的字符串 ?? ^n ?? 包含以n开头的字符串 ?=n ? ? 指定字符串后面紧跟的n的字符串 正则的懒惰性 每次在exec()中捕获的时候,只捕获第一次的内容,而不往下捕获了,这叫正则的懒惰性,每一次捕获的开始位置都是从0开始的 如何解决正则的懒惰性呢,用修饰符g来解决,全局匹配 正则的实例对象reg上有一个lastIndex属性,他是正则捕获的起始位置 正则的贪婪性: 每一次匹配都是按照最长的出结果,我们把这种功能叫正则的贪婪性 ? ?要解决正则的贪婪性则需要在元字符量词后面加? ? ? ? ---恢复内容结束--- (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |