JS 中 replace 和 replaceAll 的区别?

方法解释

两种方法都返回一个新字符串,原始字符串保持不变。并且改方法可以传两个参数。

参数一:pattern。 pattern 可以是一个 字符串 或一个 正则表达式

参数二:replacement。 replacement 可以是一个字符串或一个在每次匹配被调用的函数。

下面以参数一 pattern 传参类型不同来做区分。

1. 当 pattern 是字符串,有区别。

当 pattern 是字符串时,replace 只替换匹配到的第一个位置,replaceAll 会替换每一个匹配到的地方。代码如下:

var value = '123-234-234-234'
var pattern = '-'
console.log('replace: ' + value.replace(pattern, '/'))   
console.log('replaceAll: ' + value.replaceAll(pattern, '/'))

// 输出:
// replace: 123/234-234-234
// replaceAll: 123/234/234/234

2. 当 pattern 都是正则表达式时,没有区别。

var value = '123-234-234-234'
var pattern = /-/g
console.log('replace: ' + value.replace(pattern, '/'))   
console.log('replaceAll: ' + value.replaceAll(pattern, '/'))

// 输出:
// replace: 123/234/234/234
// replaceAll: 123/234/234/234

除此之外,两个函数的第二个参数都可以传入一个函数,用来自定义替换规则。

var value = '123-234-234-234'
var pattern = '-'
value.replace(pattern, (item, index) => {
	// item 替换元素,index 替换元素的下标
	console.log(item, index)
	return '/'
})

// 输出:
// - 3
// 123/234-234-234
  • 5
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
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 ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值