JavaScript-正则表达式中search,match,test,exec,replace,split区别

一、test和exec都是由正则表达式调用的方法

test( )方法,参数是一个字符串,如果包含正则表达式的一个匹配结果,则返回true,否则返回false。

exec()方法,参数也是一个字符串:而exec方法返回的是一个数组,其中存放匹配的结果,没有找到则返回null。

        在g模式下第二次调用exec方法会在余下的匹配项去去找匹配结果,而非g模式下却不会,每次得到的都是相同的一个结果。(具体的上一篇博客中写到了,这篇就不细写了)

二、search,match,replace,split都是由字符串调用的方法

search方法返回的是一个数字,该数字为字符串匹配结果第一个字符的下标值,如果没有找到则返回-1.

    var zw="aaaazw";
    f2=zw.search(/zw/g);
    console.log(f2);

结果会输出4,而在字符串中字符z的下标值是4。

match方法有两个作用,用于字符串中检索指定的值,用于找到一个或多个正则表达式的匹配

1.字符串的检索

检索成功返回所检索的字符串,否则返回null

2.找到一个或多个正则表达式的匹配

如果 regexp 没有标志 g,那么 match() 方法就只能在 stringObject 中执行一次匹配。如果没有找到任何匹配的文本, match() 将返回 null。否则,它将返回一个数组,其中存放了与它找到的匹配文本有关的信息。该数组的第 0 个元素存放的是匹配文本,而其余的元素存放的是与正则表达式的子表达式匹配的文本。除了这些常规的数组元素之外,返回的数组还含有两个对象属性。index 属性声明的是匹配文本的起始字符在 stringObject 中的位置,input 属性声明的是对 stringObject 的引用。

如果 regexp 具有标志 g,则 match() 方法将执行全局检索,找到 stringObject 中的所有匹配子字符串。若没有找到任何匹配的子串,则返回 null。如果找到了一个或多个匹配子串,则返回一个数组。数组元素中存放的是 stringObject 中所有的匹配子串,而且没有 index 属性或 input 属性。

    var text = "zw, ww, www,";
    var zw1 = /.w/;
    var te = text.match(zw1);
    console.log(te); 
    console.log(te.index); 
    console.log(te.input); 
    
    var zw2 = /.w/g;
    var te = text.match(zw2);
    console.log(te); 
    console.log(te.index); 
    console.log(te.input); 

明显非g模式下只找到了一个匹配结果,而g模式下则找到了所有的匹配结果。

g模式下没有index和input属性,所以输出为undefined

而当我把te改为te[3]时输出的是ww,而我该改为te[4]的时候输出undefined,因为g模式下至搜索到了四个匹配结果,存放在一个长度为4的数组中,如果访问te[4]当然不存在,所以显示越界。

 

replace方法

语法:    stringObj.replace(regexp/substr,replacement);

第一个参数:必需。字符串中要替换的子串或正则RexExp;

第二个参数:必需,一个字符串值,规定了替换文本或生成替换文本的函数。 

返回值:注意它的返回值是一个新的字符串,并没有更改原有字符串,是用 replacement 替换了 regexp 的第一次匹配或所有匹配之后得到的。 

如果 regexp 具有全局标志 g,那么 replace() 方法将替换所有匹配的子串。否则,它只替换第一个匹配子串。

    var text = "zw,ww,www,";
    var zw1 = /.w/;
    var zw2 = /.w/g;
    var te = text.replace(zw1,"aa");
    console.log(te); 
    var te = text.replace(zw2,"aa");
    console.log(te); 

很明显g模式下替换了三处,而非g模式下只替换了一处

当第一个参数是字符串而不是正则表达式时就是一个简单字符串的替换,这种情况下只会替换第一个找到的字符串

    var text = "zw,ww,www,";
    var zw1 = "ww";
    var te = text.replace(zw1,"aa");
    console.log(te); 

只替换了第一处找到的位置

replacement 可以是字符串,也可以是函数。

    var text = "zw,ww,www,";
    var zw1 = /(\w+),(\w+)/g;
    var te = text.replace(zw1,"$2,$1");//$1为zw,$2为ww,此处替换就用ww,zw替换了zw,ww
    console.log(te); 
    var te = text.replace(zw1,"$1$&");//$1为zw,$&为zw,ww,用zwzw,ww去替换
    console.log(te); 
    var te = text.replace(zw1,"$`");//位于匹配子串左侧的文本
    console.log(te); 
    var te = text.replace(zw1,"$'");//位于匹配子串右侧的文本
    console.log(te); 
    var te = text.replace(zw1,"$$");//就是用$符号替换
    console.log(te); 

split() 方法用于把一个字符串分割成字符串数组。

语法:   stringObject.split(separator,howmany)
separator必需。字符串或正则表达式,从该参数指定的地方分割 stringObject。
howmany可选。该参数可指定返回的数组的最大长度。如果设置了该参数,返回的子串不会多于这个参数指定的数组。如果没有设置该参数,整个字符串都会被分割,不考虑它的长度。

1.separator为空字符串,则 stringObject 中的每个字符之间都会被分割。

    var text = "zwwwwww";
    var zw1 = "";
    var te = text.split(zw1);
    console.log(te); 

使用该方法可以把句子切分成单词

    var text = "Happy new year";
    var zw1 = " ";
    var te = text.split(zw1);
    console.log(te); 

或者使用正则表达式作为 separator:

var words = sentence.split(/\s+/);
    var text = "Happy new year";
    var zw1 = /\s+/;
    var te = text.split(zw1);
    console.log(te); 

结果是一样的,正则表达式中\s匹配任何空白字符,包括空格、制表符、换页符等等, 等价于[ \f\n\r\t\v],而“\s+”则表示匹配任意多个上面的字符。

2.若只需要返回一部分字符,使用 howmany 参数:

    var text = "Happy new year";
    var zw1 = /\s+/;
    var te = text.split(zw1,"2");
    console.log(te); 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值