是用于匹配字符串中字符组合的模式。在 javascript中,正则表达式也是对象。
正则表通常被用来检索、替换那些符合某个模式(规则)的文本,例如验证表单:用户名表单只能输入英文字母、数字或者下划线, 昵称输入框中可以输入中文(匹配)。此外,正则表达式还常用于过滤掉页面内容中的一些敏感词(替换),或从字符串中获取我们想要的特定部分(提取)等 。
正则表达式的灵活性。
逻辑性和功能性非常强。
可以迅速地用极简单的方式达到字符串的复杂控制。
1、创建正则表达式
通常有两种方式可以创建。
1)通过调用 regexp 对象的构造函数创建
var 变量名 = new regexp(/表达式/);
2)通过字面量创建
var 变量名 = /表达式/;
// 注释中间放表达式就是正则字面量
2、测试正则表达式
test() 正则对象方法,用于检测字符串是否符合该规则,该对象会返回 true 或 fal,其参数是测试字符串。
regexobj.test(str)
其中:
regexobj —写的正则表达式
str —要测试的文本
意即检测str文本是否符合写的正则表达式规范。
例如:
给定一个正则表达式var rg = /123/
,判断我们输入的字符串是否符合规则。
var str = '123'var reg1 = new regexp(/123/);var reg2 = /abc/;console.log(reg1.test(str)) ; console.log(reg2.test(str)) ;
打印结果为;
一个正则表达式可以由简单的字符构成,比如 /abc/,也可以是简单和特殊字符的组合,比如 /ab*c/ 。其中特殊字符也被称为元字符,在正则表达式中是具有特殊意义的专用符号,如 ^ 、$ 、+ 等。
正则表达式中的边界符(位置符)用来提示字符所处的位置,主要有两个字符。
如果 ^ 和 $ 在一起,表示必须是精确匹配。
字符类表示有一系列字符可供选择,只要匹配其中一个就可以了。所有可供选择的字符都放在方括号内。
1、[]方括号类
/[abc]/.test('andy') // true
后面的字符串只要包含abc中任意一个字符,都返回true。
2、[-]方括号内部 范围符-
/^[a-z]$/.test(c') // true
方括号内部加上 – 表示范围,这里表示 a 到 z 26个英文字母都可以。
3. [^] 方括号内部 取反符^
/[^abc]/.test('andy') // fal
方括号内部加上 ^ 表示取反,只要包含方括号内的字符,都返回 fal 。
注意和边界符 ^ 区别,边界符写到方括号外面。
4. 字符组合
/[a-z1-9]/.test('andy') // true
方括号内部可以使用字符组合,这里表示包含 a 到 z 的26个英文字母和 1 到 9 的数字都可以。
量词符用来设定某个模式出现的次数。
var reg = /^a*$/; // * 相当于>=0,可以出现0次或很多次var reg = /^a+$/; // + 相当于>=1,可以出现1次或很多次var reg = /^a?$/; // ? 相当于1||0,可以出现0次或1次var reg = /^a{3}$/; // {3}就是重复a字符3次var reg = /^a{3,}$/; // {3,}就是重复a字符 大于等于3次var reg = /^a{3,16}$/; // {3,16}就是重复a字符 大于等于3次 小于等于16次
比如现在做一个用户名验证的案例,如果用户名输入合法,则提示信息为:用户名合法,颜色为绿色;如果用户名输入不合法,则提示信息为:用户名不合法,并且颜色为绿色。
代码如下:
<!doctype html><html lang="en"><head> <meta chart="utf-8"> <meta http-equiv="x-ua-compatible" content="ie=edge"> 半圆的面积怎么算<meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>document</title> <script src="jquery.js"></script> <style> .success{ color:green; } .wrong{ color:red; } </style></head><body> <label for="">用户名: <input type="text" class="uname"><span></span> </label> <script> $(function(){ var reg = /^[a-za-z0-9_-]{6,16}$/; $('.uname').bind('blur',function(){ let str = $(this).val(); 我们不是最好的 if($('input').val === null){ $('span').removeclass(); } if(reg.test(str)){ if($('span').hasclass('wrong')) 秦始皇名言 $('span').removeclass() $('span').html('输入格式正确'); $('span').addclass('success') }el{ $('span').html('输入格式错误'); $('span').addclass('wrong') } }) }) </script></body></html>
显示效果为:
大括号 量词符. 里面表示重复次数
中括号 字符集合。匹配方括号中的任意字符.
小括号 表示优先级
预定义类指的是某些常见模式的简写方式。
match()方法:爸爸去哪儿主题曲歌词根据正则匹配出所有符合要求的内容匹配成功后将其保存到数组中,匹配失败则返回fal。
例如:
var str = "it's is the shorthand of it is";var reg1 = /it/gi;str.match(reg1); // 匹配结果:(2) ["it", "it"]var reg2 = /^it/gi;str.match(reg2); // 匹配结果:["it"]var reg3 = /s/gi;str.match(reg3); // 匹配结果:(4) ["s", "s", "s", "s"]var reg4 = /s$/gi;str.match(reg4); // 匹配结果:["s"]
arch()方法:arch()方法可以返回指定模式的子串在字符串首次出现的位置,相对于indexof()方法来说功能更强大。
例如:
var str = '123*abc.456';console.log(str.arch('.*')); // 输出结果:0console.log(str.arch(/[\.\*]/)); // 输出结果:3
split()方法:split()方法用于根据指定的分隔符将一个字符串分割成字符串数组,其分割后的字符串数组中不包括分隔符。
例如:
按照字符串中的“@”和“.”两种分隔符进行分割。
var str = 'test@123.com';var reg = /[@\.]/;var split_res = str.split(reg);console.log(split_res); // 输出结果:(3) ["test", "123", "com"]
正则匹配方式分割字符串时,还可以指定字符串分割的次数。
var str = 'we are a family';var reg = /\s/;var split_res = str.split(reg, 2);console.log(split_res); // 输出结果:(2) ["we", "are"]
replace()方法:replace()方法用于替换字符串,用来操作的参数可以是一个字符串或正则表达式。
例如:写一个查找并替换敏感词的案例(过滤汉字和‘bad’这个单词):
<!doctype html><html lang="en"><head> <meta chart="utf-8"> <meta http-equiv="x-ua-compatible" content="ie=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>document</title></head><body style="display:flex"> <div> <p>过滤前的内容</p> <textarea name="" id="" cols="30" rows="10"></textarea> <button id = 'btn'>过滤</button> </div> <div> <p>过滤后的内容</p> <textarea name="" id="" cols="30" rows="10"></textarea> </div> <script> var text = document.querylectorall('textarea'); console.log(text); var btn = document.querylector('button'); btn.onclick = function() { text[1].value = text[0].value.replace(/qq空间密码怎么设置(bad)|[\u4e00-\u9fa5]/gi, '*'); } </script></body></html>
运行效果为:
以上就是深入了解javascript中正则表达式的使用的详细内容,更多关于javascript正则表达式的资料请关注www.887551.com其它相关文章!
本文发布于:2023-04-04 03:06:56,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/cf491f108a4dd088541fd0a3efdd0a93.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:深入了解JavaScript中正则表达式的使用.doc
本文 PDF 下载地址:深入了解JavaScript中正则表达式的使用.pdf
留言与评论(共有 0 条评论) |