replce的理解(replucation)

大家好!今天让小编来大家介绍下关于replce的理解的问题,以下是酷知号的小编对此问题的归纳整理,让我们一起来看看吧。

replce的理解

replace是字符串对象的公有方法,  str.replace(findStr,newStr)

replace:把字符串里符合规则的部分替换成新的部分.

先讨论第一个参数,也就是规则

1.规则是字符串的情况,每当执行一次只能替换一次.

var str = "hua123hua456";
var newStr = str.replace("hua","en");
console.log(newStr); // "en123hua456"
newStr = newStr.replace("hua","en");
console.log(newStr); // "en123en456"

2.规则是正则的情况,和exec捕获一样,把所有和我们正则匹配的部分都捕获到,然后把捕获的内容替换成我们需要替换的新内容

var str = "hua123hua456";
var newStr = str.replace(/hua/,"en");
console.log(newStr); // "en123hua456"

好像跟想象中的不一样,因为正则的捕获有懒惰性,所以必须用g,也就是/hua/g,这样就en123en456

然后讨论第二个参数,也就新内容

新内容是字符串的情况下,上面都是例子

新内容是回调函数的情况下,稍微有点复杂

1)回调函数执行多少次,取决于正则在字符串中捕获的次数
2)每次执行回调函数,里面传递的参数值arguments和我们exec捕获的结果是非常类似的,即使正则有分组,我们同样可以arguments获取到分组捕获的内容
3)return 返回的结果是啥,就相当于把当前这次大正则的内容替换成你返回的内容

var str = "hua123hua456";
var reg = /hua(d)/g;
var newStr = str.replace(reg,function () {
    console.log("数数我出现的次数"); // 2
    console.log(arguments); // 和下面的接近
    console.log(reg.exec(str));
    return +arguments[1]+1; // 新内容是arguments[1]的值加1
});
console.log(newStr); // "223556"

以上就是小编对于replce的理解问题和相关问题的解答了,replce的理解的问题希望对你有用!

文章来自互联网,只做分享使用。发布者:酷知号,转转请注明出处:https://www.kuzhihao.com/article/406057.html

(0)
上一篇 2023年8月28日 20:38
下一篇 2023年8月28日 20:39

相关推荐