replace 方法的第二个参数为函数时的用法

文章介绍了在JavaScript中,当`String.prototype.replace()`方法的第二个参数为函数时,如何处理字符串。通过一个例子展示了如何找到字符串中跟在字母后面的连续数字并在它们前后添加特定字符,同时解释了函数参数的含义,包括subStr、group1、group2、offset、input和params。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

一、前言

二、replace 方法第二个参数为函数时,该函数参数如下

三、代码示例如下


一、前言

进入正题前先放两个链接:

MDN-String.prototype.replace()

MDN-String.prototype.replaceAll()

想了解它们详细用法的朋友们通过上面的链接进入MDN即可,这里不做赘述;想快速了解用法的往下看。

二、replace 方法第二个参数为函数时,该函数参数如下

三、代码示例如下


    let str = 'abcd12eddddf222AAA';
    // 需求:找到 str 中跟在字母后面的连续数字,在它们的开头和结尾加上字符@。
    // 如 'abcd12eddddf222AAA' => 'abcd@12@eddddf@222@AAA'
    let reg = /\w(\d+)(\w)/g; // 这里有两个捕获组,第一个是连续数字,第二个是连续数字后面的一个字母
    let result = str.replace(reg, (subStr, group1, group2, offset, input, params) => {
        // subStr 匹配到的子字符串, group1, group2 为捕获组, 
        //offset 匹配到的子字符串在原字符串中的偏移量, input 为原字符串, reg中没有命名捕获组 params 为 undefined
        console.log(subStr, group1, group2, offset, input, params);
        return subStr[0] + '@' + group1 + '@' + group2;
    }); 
    console.log(str);
    console.log(result);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值