正则表达式
正则表达式,又称规则表达式。
正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。
正则表达式通常用来检索、替换那些符合某个规则的文本。
正则表达式的作用:
1.灵活性、逻辑性和功能性非常的强
2.可以迅速地用极简单的方式达到字符串的复杂控制
3.对于刚接触的人来说,比较晦涩难懂
一:常见正则表达式
元字符
\d : 匹配任意一个数字,0~9 中的任意一个。
\s : 匹配任意一个空白字符。
\b : 匹配一个单词边界,不匹配任何字符。
\w : 匹配任意一个字符( 字母、 数字、下划线 )。
. : 匹配任意一个字符,除了换行符( \n )。
\n : 查找换行符。
\u : 通常用来匹配汉字。
表达式 “\d”,"\s","\b","\w",对应的大写字母表示相反的意义。
如:\D 匹配所有的非数字字符(反选)。
方括号
[abc] : 查找方括号之间的任何一个字符。
[^abc] : 查找任何不在方括号之间的字符(反选)。
[0-9] : 查找任何从 0 至 9 的数字。
[a-z] : 查找任何从小写 a 到小写 z 的字符。
[A-Z] : 查找任何从大写 A 到大写 Z的字符。
量词
n+ : 匹配任何包含至少一个 n 的字符串。{1,}
n? : 匹配任何包含零个或一个 n 的字符串。{0,1}
n* : 匹配任何包含零个或多个 n 的字符串。{0,}
n{X} : 匹配包含 X 个 n 的序列的字符串。
n{X,Y} : 匹配包含 X 到Y 个 n 的序列的字符串。
^n : 匹配任何开头为 n 的字符串。
n$ : 匹配任何结尾为 n 的字符串。
锚字符(必须用在正则表达式的开头和结尾)
^ 行首匹配
$ 行尾匹配
其他
| : 匹配左边或者右边
\ : 转义符
特殊标点符号,在前面加 \ 后,就代表该符号本身
^ 要匹配 “^” 字符本身,请使用 ^
( ) 要匹配小括号本身,请使用 ( 和 )
其他特殊标点符号 [ ] { } . ? + * |
Unicode编码16进制的utf-8汉字编码:
4e00最小中文字符 9fa5最大中文字符
/[\u4e00-\u9fa5]+/ 常用汉字编码范围
var reg=/[\u4e00-\u9fa5]+/g; //匹配汉字
var str='我爱你中国';
console.log(reg.test(str));
元字符 | 描述 |
---|---|
\ | 将下一个字符标记符、或一个向后引用、或一个八进制转义符。例如,“\n”匹配\n。“\n”匹配换行符。序列“\”匹配“\”而“(”则匹配“(”。即相当于多种编程语言中都有的“转义字符”的概念。 |
^ | 匹配输入字行首。如果设置了RegExp对象的Multiline属性,^也匹配“\n”或“\r”之后的位置。 |
$ | 匹配输入行尾。如果设置了RegExp对象的Multiline属性,$也匹配“\n”或“\r”之前的位置。 |
* | 匹配前面的子表达式任意次。 |
+ | 匹配前面的子表达式一次或多次(大于等于1次)。 |
\d | 匹配一个数字字符。等价于[0-9]。grep 要加上-P,perl正则支持 |
\D | 匹配一个非数字字符。等价于[^0-9]。grep要加上-P,perl正则支持 |
\f | 匹配一个换页符。等价于\x0c和\cL。 |
\n | 匹配一个换行符。等价于\x0a和\cJ。 |
\b | 匹配一个单词的边界,也就是指单词和空格间的位置(即正则表达式的“匹配”有两种概念,一种是匹配字符,一种是匹配位置,这里的\b就是匹配位置的)。 |
\s | 匹配任何不可见字符,包括空格、制表符、换页符等等。等价于[ \f\n\r\t\v]。 |
\t | 匹配一个制表符。 |
\u | 匹配汉字 |
二:实战中常用正则表达式
嘿!(● ̄(エ) ̄●)兄die,下面让我们一起康康在实际操作中一些常用的正则表达式吧
过滤HTML标签
尖括号里是除了尖括号之外其他字符 /<[^<>]+>/g
匹配邮政编码
开头非0的6位数字 /^[1-9]\d{5}$/
文件格式检测
文件格式结尾为 .格式
/\.(png|jpe?g|gif)$/
/\.(mp4|webm|ogg|mp3|wav)$/
手机号
/^(1|\+861)[3-8]{1}\d{9}$/
身份证
身份证号码为15位或者18位,15位为全数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X
/(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/
Email地址
^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$
中文检测
/[\u4e00-\u9fa5]+/g
QQ号验证
/^[1-9]\d{4,10}$/
座机号码
010-86123456-2345
023-67622000-02
0755-66608483
开头为0,后面是2或三位数字加上 - 开头为非零的八位数字,结尾是 - 加1到4位数字的分机号
(0\d{2,3}-)?[1-9]\d{7}(-\d{1,4})?
判断IE版本:
^.*MSIE [5-8](?:\\.[0-9]+)?(?!.*Trident\\/[5-9]\\.0).*$
帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线)
^[a-zA-Z][a-zA-Z0-9_]{4,15}$
密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线)
^[a-zA-Z]\w{5,17}$
强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间)
^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$
邮件格式
简单验证 /^\w+@[a-z0-9]+\.[a-z]+$/
具体验证 /^\w{2,18}@[0-9a-z]{1,10}(\.[a-z]{2,3}){1,2}$/
IP地址
\d+\.\d+\.\d+\.\d+ (提取IP地址时有用)
删除多余空格
str.replace(/\s+/,'');
删除首尾空格
str.replace(/^\s+/,'');
str.replace(/\s+$/,'');
三:字符串的函数:
string对象方法
1:match()
格式:字符串.match(正则)
功能:在字符串中匹配这个正则是否存在
返回值:如果存在,返回一个数组,数组放着,匹配到的子串如果不存在,返回null
:2:search()*
格式:字符串.search(正则)
功能:在字符串中,查找正则表达式,第一次出现的位置
返回值:如果查找到,返回,查找到的下标 查找不到,返回-1
3:replace()
格式:字符串.replace(oldStr/正则, newStr);
功能:用newStr将oldStr替换,
返回值:替换成功的新字符串。
:4:split()*
格式:字符串.split(分割符/正则);
功能:用分割符将原字符串进行分割
返回值:分割剩下的子串组成的数组。
正则表达式可以调用字符串的方法
举个栗子
正则调用字符串里的数字。
方法一:
var str="警察:110,急救:120,火警:119";
//把里面所有的数字全部显示出来
var array=str.match(/\d{5}/g);
console.log(array);
方法二:
var reg = new RegExp(/[h]/gi);
var str = "HhpphH";//SSppSS
str = str.replace(reg, "S");
console.log(str);
正则对象方法
1.test:检索字符串中指定的值 返回 true 或 false
reg.test(str);
2.exec: 检索字符串返回查找结果的第一个值
reg.exec(str);
3.compile: 该方法可以重编辑指定的正则表达式
var num='13520006789';
var reg=/13[4-9]\d{8}/g;
console.log(reg.test(num));
reg.compile('13[0-3][0-9]{8}','g');//修改正则
console.log(reg.test(num));//false
小伙伴们,有关js正则的知识还要很多,我写的就是一些我平时所遇到的哦,第一次写博客有点小刺激哈哈哈哈 嗝
如果jio的还可以的小伙伴可以给我点个赞点点关注哦~嘻嘻 么么哒~~~~