Javascript中正则表达式的应用详解
正则表达式 在前端中的应用也是比较常见的,我们在有时候也需要 用js 对某些字符串进行查找\捕获 或者 替换. js 中正则表达式 一般应用在string类型和 RegExp 两种类型中。
string
search
search() 方法 用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串,并返回子串的起始位置。
'Hello World!'.search(/world/i); // 6 返回匹配出的第一个字符串的开始位置索引, //与 indexOf 方法类似,但是 search方法 可以支持 正则表达式,功能更加强大
replace
修改某个字符串 将内容中的某个子串 替换为其他内容,可以支持字符串替换,也支持正则表达式替换,建议正则表达式替换,功能会更加强大。返回值为替换处理完成的字符串
// 1. 最简单的应用,world 替换为 ljz 'Hello World!'.replace(/world/i,'ljz'); // 返回值('Hello ljz!') i模式可以忽略大小写 // 2 如果要替换 的字符串为动态字符串,并且可能包含特殊符号 比如 '?' 这样构造正则表达式, //如果包含特殊符号会影响正则匹配,会有可能匹配不到,所以可以考虑使用字符串替换. // 如下,要将src属性为指定值 的 标签 加上classname属性为 ‘aaaImg' const str = '/aaa/bbb?fileid=111'; '<img src="/aaa/bbb?fileid=111" ><h2>123</h2><p>444</p>'.replace(`src="${str}"`,`src="${str}" className="aaaImg"`); // 返回值('<img src="/aaa/bbb?fileid=111" className="aaaImg" ><h2>123</h2><p>444</p>') // 3. 上述情况如果只适用于替换一个字符串,如果我要替换的串是有多个呢,有两种解决思路, 一是可以继续使用字符串替换,可以使用replaceAll方法,用法与repalce相同,但是可以进行全部替换,ie浏览器不支持repalceAll方法,如果要考虑兼容ie ,那就只能考虑第二种方式了。 // 使用正则表达式,正则表达式有全局模式,可以支持全部替换,就是需要对要构造正则表达式的动态字符串进行处理一下,避免特殊符号影响匹配的情况。 // 可以先对 动态字符串进行转码,在对要处理的字符串进行转码处理,然后进行全局替换,替换完成再进行解码还原字符串就可以了。 '<img src="/aaa/bbb?fileid=111" ><h2>123</h2><p>444</p><img src="/aaa/bbb?fileid=111" >'; const regExp = new RegExp(encodeURIComponent('src="/aaa/bbb?fileid=111"'),'g'); const data = encodeURIComponent(dataStr).replace(regExp, decodeURIComponent('src="/aaa/bbb?fileid=111 className="aaaImg"')); decodeURIComponent(data); // 返回值('<img src="/aaa/bbb?fileid=111 className="aaaImg" ><h2>123</h2><p>444</p><img src="/aaa/bbb?fileid=111 className="aaaImg" >')
match:
string.match(regexp)
;可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。规定要匹配的模式的RegExp对象。如果该参数不是RegExp对象,则需要首先把它传递给RegExp构造函数,将其转换为RegExp 对象,返回值为一个数组,里面存放匹配出的各项字符串。
var str=”The rain in SPAIN stays mainly in the plain ; var n=str.match(/ain/gi); // 输出结果: ain,AlN,ain,ain ,match与 下面exec方法类似,只不过match是字符串的方法,exec是 正则表达式的方 法。
RegExp
JavaScript中,RegExp对象是一个预定义了属性和方法的正则表达式对象
test:
用于检测一一个字符串是否匹配某个模式,如果字符串中含有匹配的文本,则返回true,否则返回false。
const reg = new RegEx//jz/); reg.test(hello ljz!); // true
exec:
用于检索字符串中的正则表达式的匹配。该函数返回一个数组,其中存放匹配的结果。如果未找到匹配,则返回值为null。
// 最基本匹配 const reg1 = new RegExp(/ ljz)d+); // 匹配ljz后面携带数字的串 reg1.exec('cmasklnvjksdfbnk12345 6cdsnjkvbsdfhjjz123vbfsdhj)[0]; // 123 //捕获对应的字符串 // ()会把每个分组里的匹配的值保存起来,exec得到一一个数组,此时捕获分组会把匹配到的值保存起来,从数组下标[1]开始依次存储 // [^]表示以此结束的串([^"]*) 就可以是捕获分组以"结束的串 const reg2 = new RegExp(/id="([^"]*/); //要捕获标签字符串中的id属性值 reg2.exec("<img id=\"cFF2vAMVq" src=\"/aaa/bbb\"/>');//返回数组。0为匹配到的字符串('d="cFF2vAMVq'),1为要捕获的串('cFF2vAMVq')
总结
本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!
最新评论