Javascript中正则表达式的应用详解

Javascript中正则表达式的应用详解

目录

string

search

replace

match:

RegExp

总结

正则表达式 在前端中的应用也是比较常见的,我们在有时候也需要 用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') 总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注易知道(ezd.cc)的更多内容!

推荐阅读

    Javascript中 toFixed四舍六入方法

    Javascript中 toFixed四舍六入方法,浮点,手动,银行家,进,javascript中toFixed使用的是银行家舍入规则。银行家舍入:所谓银行家舍入法,其实

    javascript怎么隐藏元素值

    javascript怎么隐藏元素值,隐藏,元素,设置,显示,位置,属性,javascript隐藏元素值的方法:1、设置元素style属性中的display,语句如“t.style.displ

    javascript对象怎么转换成字符串

    javascript对象怎么转换成字符串,字符串,参数,对象,序列化,属性,数组,在javascript中可以使用“JSON.stringify()”方法将对象转换成字符串,其语

    javascript怎么将字母转为小写

    javascript怎么将字母转为小写,方法,字符串,函数,语法,主机,语言,javascript字母转为小写的方法:1、使用toLowerCase()函数,语法“string.toLower

    javascript怎么实现二维码

    javascript怎么实现二维码,二维码,二维码生成,下载,插件,扫描二维码,操作,javascript实现二维码的方法:1、下载qrcodejs插件;2、使用qrcode实现二

    正则表达式不包含

    正则表达式不包含,正则,数字,字符串,正则表达式,位置,下划线,正则表达式不管是做哪方面开发的朋友都会使用到,但是有好多人不太懂正则正则表达式

    javascript如何获取字符串长度

    javascript如何获取字符串长度,字符,获取,属性,字符串长度,字符串,输出,javascript获取字符串长度的方法:1、使用length属性按字符来获取字符串

    javascript怎么类型转换

    javascript怎么类型转换,方法,字符串,转换,转换成,类型,数字,方法:1、使用“+”运算符自动进行转换。2、使用JS内置的函数进行转换,例toString()

    javascript如何去掉空格

    javascript如何去掉空格,去除,替换,方法,删除,文本,字符串,javascript去掉空格的方法:1、通过“str.replace(/\s+/g,"");”去除所有空格;2、通

    javascript中定义数组的方法有哪些

    javascript中定义数组的方法有哪些,数组,数组名,列表,元素,语句,方法,javascript中定义数组的方法:1、使用“var 数组名=[值列表]”语句;2、使用