js中 replace replaceAll 全部替换

js中的replace方法只能替换第一个模板,
在java语言中有给出的replaceAll方法能够实现这样的功能,但很遗憾javascript没有提供这样的方法。
但replace方法要比我们想象的强大,实际上通过它我们可以实现我们的需求的。
下面是JavaScript.chm文档里面对这个方法的说明。
replace 方法
返回根据正则表达式进行文字替换后的字符串的复制。
stringObj.replace(rgExp, replaceText)

参数

stringObj:必选项。要执行该替换的 String 对象或字符串文字。该字符串不会被 replace 方法修改。 
rgExp :必选项。为包含正则表达式模式或可用标志的正则表达式对象。也可以是 String 对象或文字。如果 rgExp 不是正则表达式对象,它将被转换为字符串,并进行精确的查找;不要尝试将字符串转化为正则表达式。
replaceText :必选项。是一个String 对象或字符串文字,对于stringObj 中每个匹配 rgExp 中的位置都用该对象所包含的文字加以替换。在 Jscript 5.5 或更新版本中,replaceText 参数也可以是返回替换文本的函数。

看非期望的实现效果图。


正确使用实例:
var s = "*****kkk****";
s.replace("*","");//只能替换第一个字符
s.replace(new RegExp(/(\*)/g),'')

var replaceStr = "\\*";//*是特殊字符,要转义一下,加个杠。
s.replace(new RegExp(replaceStr,'gm'),'')


如下处理,也是可以使用滴。
str.split(replaceStr).join('')
如图:






在JavaScriptreplacereplaceAll都是用于替换字符串的字符或字符串的方法。但是它们之间有一些区别。 1. replace方法:replace方法只替换匹配到的第一个位置。当pattern是一个字符串时,replace方法将替换第一个匹配到的字符或字符串。当pattern是一个正则表达式时,replace方法将替换第一个匹配到的位置。例如: - 字符替换:value.replace(pattern, replacement) - 正则表达式替换:value.replace(pattern, replacement) 2. replaceAll方法:replaceAll方法替换所有匹配到的位置。当pattern是一个字符串时,replaceAll方法将替换所有匹配到的字符或字符串。当pattern是一个正则表达式时,replaceAll方法将替换所有匹配到的位置。例如: - 字符替换:value.replaceAll(pattern, replacement) - 正则表达式替换:value.replaceAll(pattern, replacement) 总结来说,replace方法只替换第一个匹配到的字符或字符串,而replaceAll方法替换所有匹配到的字符或字符串。此外,replaceAll方法支持正则表达式替换,而replace方法不支持正则表达式替换。 在Javareplace方法和replaceAll方法的使用也类似。replace方法只替换第一个匹配到的字符或字符串,而replaceAll方法替换所有匹配到的字符或字符串。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [JS replacereplaceAll 的区别?](https://blog.csdn.net/userkang/article/details/109580023)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [replacereplaceAll的区别](https://blog.csdn.net/ChineseSoftware/article/details/122938738)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值