正则-RegExp
正则-RegExp
正则,是一条规则,用于检验字符串格式,目标就是字符串;
只要是表单提交的数据都是字符串
定义:
1,var reg=/格式/
2,var reg=new regexp()
方法:
两大功能---匹配,test() 成功就是true,反之false;
捕获,exec() 成功就会拿出来,没有就是null;
修饰符:
i 忽略大小写
g 全局匹配
m 多行匹配
如何使用修饰符:
1,var reg=/hello/gi 字面量方式
2,var reg=new regexp(“hello”g) 实例方式
正则的方括号:
[abc] 代表查找方括号中的任何字符
[^abc] 代表查找不在方括号中的字符
[0-9] 代表查找0-9之间的数字
[a-z] 代表查找小写a到小写z之间
[A-Z] 代表查找大写A到大写Z之间
[A-z] 代表查找大写Z到小写z之间
(red|blue|black) 查找任何指定的选项
正则的元字符:
. 代表单个字符(任意字符,数字字母下划线空格等)
\w 代表单词字符(数字字母下划线)
\W 代表非单词字符
\d 代表数字
\D 代表非数字
\s 代表空白字符
\S 代表非空白字符
\b 代表单词边界
\B 代表非单词边界
正则的量词:
n+ 代表至少一个n的字符
n* 代表0个或多个n(添加相邻元素)
n? 代表0个或一个n(添加相邻元素,0个或一个全部拿走)
n{x} 包含x个n
n{x,} 包含至少x个n
n{x,y} 包含大于等于x,小于等于y个n
n$ 以n结尾
^n 以n开头
?=n 指定字符后面紧跟
字符串方法:(跟正则有关的)
1,match()查找一个或多个和正则相匹配的,有就返回的是查找的结果,没有就null
2,search()匹配和正则相同的字符,有就返回索引,没有就-1
3,replace()匹配和正则相同的幷替换掉,返回的是换之后的
正则的理解:
1,贪婪性:
每一次匹配都是按最长的出结果,这种功能叫正则的贪婪性
2,懒惰性:
每一次在exec()中捕获的时候,只捕获第一次匹配的内容,而不再往下捕获了,这个叫正则的懒惰性;每一次捕获的位置都是从0开始
如何解决正则的懒惰性?修饰符g
正则的实例对象reg上有一个lastindex属性,他是正则捕获的起始位置
如何解决正则的贪婪性?在元字符量词后面加问号
分组捕获:
正则带(),数分组个数的时候从左往右
var reg=/(a)(b)/
相当于大正则里面带了两个小正则 第一组(a)第二组(b)
分组捕获作用:
1,改变优先级 2,分组引用 \1 \2
\1 代表和第一个分组出现一模一样的内容
\2 代表和第二个分组出现一模一样的内容
var reg=/(\w)\1(\w)\2/
var st="ssdd"
var s=reg.test(st)
console.log(s) //true
正则reg中的规则第一个是一个分组;且是一个单词字符
第二个是一个分组引用;要求和第一组一模一样
分组捕获:
前提是正则存在分组,不仅把大正则内容捕获到,把小正则内容也捕获到
如何解除分组捕获:
在这个分组前面加问号冒号?:
最新文章
- WordPress建站和搭独立博客
- css 绘制对话框三角符号
- 每日一语:What is he getting at?
- Linux中变量$#,$@,$0,$1,$2,$*,$$,$?的含义(转载)
- 【剑指offer】判断二叉树是否为平衡二叉树
- C语言之分配
- CSS3中transform几个属性值的注意点
- SQL Server数据库漏洞评估了解一下
- 使用lombok自动生成链式调用
- native-echarts 图形组件
- Spark机器学习中ml和mllib中矩阵、向量
- WIN10快捷键
- jmeter打开其他设备转过来的历史脚本出现报错
- java 获取两个日期之间的所有天数
- JavaScript相关基础知识点
- MySQL数据库的安装与基本操作
- 3Sum(or k_Sum)
- 2018.08.27 rollcall(非旋treap)
- 小程序之底部tabBar
- WinForm获取当前路径汇总