JavaScript正则表达式简介及使用实例

JS正则简介:
     RegExp 对象表示正则表达式,它是对字符串执行模式匹配的强大工具。 正则表达式是构成搜索模式的字符序列。该搜索模式可用于文本搜索和文本替换操作。
    实例:

var patt = /w3school/i;
//  /w3school/是搜索模式;i(对搜索模式中的字母大小写不敏感)
//最后包含属性 "g"、"i" 和 "m",分别用于指定全局匹配、区分大小写的匹配和多行匹配

直接量语法: /pattern/attributes
创建RegExp 对象语法: new RegExp(pattern, attributes);//参数 pattern 是一个字符串,指定了正则表达式的模式或其他正则表达式。attributes 是一个可选的字符串,包含属性 “g”、“i” 和 “m”,分别用于指定全局匹配、不区分大小写的匹配和多行匹配。


正则相关:
方括号:

方括号用于查找某个范围内的字符:

表达式 描述
[abc] 查找方括号之间的任何字符。
[^abc] 查找任何不在方括号之间的字符。
[0-9] 查找任何从 0 至 9 的数字。
[a-z] 查找任何从小写 a 到小写 z 的字符。
[A-Z] 查找任何从大写 A 到大写 Z 的字符。
[A-z] 查找任何从大写 A 到小写 z 的字符。
[adgk] 查找给定集合内的任何字符。
[^adgk] 查找给定集合外的任何字符。
(red|blue|green) 查找任何指定的选项。

正则元字符:

元字符(Metacharacter)是拥有特殊含义的字符:

元字符 描述
. 查找单个字符,除了换行和行结束符。
\w 查找单词字符。
\W 查找非单词字符。
\d 查找数字。
\D 查找非数字字符。
\s 查找空白字符。
\S 查找非空白字符。
\b 匹配单词边界。
\B 匹配非单词边界。
\0 查找 NUL 字符。
\n 查找换行符。
\f 查找换页符。
\r 查找回车符。
\t 查找制表符。
\v 查找垂直制表符。
\xxx 查找以八进制数 xxx 规定的字符。
\xdd 查找以十六进制数 dd 规定的字符。
\uxxxx 查找以十六进制数 xxxx 规定的 Unicode 字符。

正则量词:

量词 描述
n+ 匹配任何包含至少一个 n 的字符串(一次或多次)。
n* 匹配任何包含零个或多个 n 的字符串。
n? 匹配任何包含零个或一个 n 的字符串。
n{X} 匹配包含 X 个 n 的序列的字符串。
n{X,Y} 匹配包含 X 至 Y 个 n 的序列的字符串。
n{X,} 匹配包含至少 X 个 n 的序列的字符串。
n$ 匹配任何结尾为 n 的字符串。
^n 匹配任何开头为 n 的字符串。
?=n 匹配任何其后紧接指定字符串 n 的字符串。
?!n 匹配任何其后没有紧接指定字符串 n 的字符串。

RegExp 对象方法:

方法 描述 FF IE
compile 编译正则表达式。 1 4
exec 检索字符串中指定的值。返回找到的值,并确定其位置。 1 4
test 检索字符串中指定的值。返回 true 或 false。 1 4

支持正则表达式的 String 对象的方法

方法 描述 FF IE
search 检索与正则表达式相匹配的值。 1 4
match 找到一个或多个正则表达式的匹配。 1 4
replace 替换与正则表达式匹配的子串。 1 4
split 把字符串分割为字符串数组。 1 4

JS正则使用实例


判断用户的输入是不是有效手机号码?

                //test检验是否符合特定规范
                //定义正则表达式
                var phone = document.getElementById("txtphone").value;
                //var msgstr = /^[0-9]{11}/;
                //var result=msgstr.test(phone);//检验是否符合特定格式
                //alert(result);
                var msgstr = /\d{11}/g;//设置为全局变量,用于全部循环检索(实现原理:会记录查找到的索引位置和长度,跳过依次查询)
                var result = msgstr.exec(msg);//默认只返回第一个结果,所以要循环输出
                while (result) {//只要不是null或underfined就是找到结果了就是为True
                   // alert(result);//打印该值
                    result = msgstr.exec(msg);
                };

判断用户输入的邮箱是否是有效的?

                //邮箱格式检索
                var emailstr = /\w+\.\w+@\w+\.(\w+)+/;
                var res=emailstr.test(phone);
                //alert(res);

正则分组查询:

                //分组查询
                var groupstr = /(\d{3})\d{4}(\d{4})/g;
                var str = groupstr.exec(msg);
                //结果第一组是匹配的字符串,第二组是第一个匹配,第三组是第二个匹配
                //alert(str.toString());//13013582532  130  1358

String使用正则表达式进行字符串替换:

                //字符串的替换
                var results=msg.replace(/(\d{3})(\d{4})(\d{4})/g, '$1****$3');//$1指定字符串第一部分原样输出
                //alert(results);

String使用正则表达式去除两边空格:

                //去除两端空格
                var msgstr = "       hellow         ";
                //将前后的空白换成空字符,空字符如果加空格就一个字符否则就是空字符也是去空格
                var resstr = msgstr.replace(/^\s+/, '').replace(/\s+$/, '');
                //
                var s=msgstr.trim();//实现02
                alert(s);
发布了23 篇原创文章 · 获赞 3 · 访问量 2041

猜你喜欢

转载自blog.csdn.net/MrLsss/article/details/104095665