replace()第二个参数是函数

当replace() 方法的第二个参数 replacement是函数而不是字符串时,每次匹配都调用该函数,将这个函数的返回的字符串将作为替换文本使用。这个函数是自定义的替换规则。

当第二个参数是函数时,这个函数的前三个参数():

1、当正则没有分组的时候,传进去的第一个实参是正则捕获到的内容,第二个参数是捕获到的内容在原字符串中的索引位置,第三个参数是原字符串(输入字符串)

2、当正则有分组的时候,第一个参数是总正则查找到的内容,后面依次是各个子正则查找到的内容。

2、传完查找到的内容之后,再把总正则查找到的内容在原字符串中的索引传进(就是arguments[0]在str中的索引位置)。最后把输入字符串(就是原字符串)传进去

'border-top'.replace(/(\-)([a-z])/g, function(match, $1, $2, offset, string) {
    console.log(match);
    console.log($1);
    console.log($2);
    console.log(offset);
    console.log(string);
    $1 = '';
    $2 = $2.toUpperCase();
    return $1 + $2;
})
// => -t 
// => -
// => t
// => 6
// => border-top
// => "borderTop"
posted @ 2021-12-24 15:56  naonaoa  阅读(456)  评论(0编辑  收藏  举报