基本用法
var s = 'abcde';高级用法
s = s.replace(/bc/, '~');
console.log(s); // 'a~de'
第二个参数可以传入一个函数:
function(match, p1, p2, ..., pn, offset, str) {}
参数可以简单理解为:
函数需要返回一个新的字符串值,该值就是我们需要接收的值。
对应我的需求,现在有一个超长的名字,比如它是:abcdefghijklmnopqrstuvwxyz1234567890,现在需要将其缩短,策略是前20个字符保留,后5个字符保留,中间所有字符替换为 ~,就可以使用上面函数:
var name = "abcdefghijklmnopqrstuvwxyz1234567890";
name = name.replace(/^.{20}(.*).{5}$/g, function(match, p1, offset, str) {
return match.replace(p1, "~");
就会得到需要的 abcdefghijklmnopqrst~67890。
参数字符串
使用参数字符串,需要通过关键字符 $ 来获取,平时使用时如果用到过 $ 作为替换字符的话会有注意:
它可以获取对应的内容,但是不要直接对参数字符串进行修改:
// 错误,得到结果为 ~
name = name.replace(/^.{20}(.*).{5}$/g, "$1".replace(/.*/, "~"));
上面这种写法是不会得到正确结果的,因为 "$1".replace(/.*/, "~") 会先被解析成字符串字面量,与 $& 效果相同,不会再将 $1 当做一个参数。所以这样得到的结果是且仅仅是一个 ~。
得到 ~ 的步骤是:
将 $1 替换为了 ~,所以是将 ~ 作为了替换内容
正则匹配了全局内容,所以全局内容被替换为了 ~
replace 返回的结果是 ~,name 被重新赋值为 ~
所以,这种方式不能在参数字符串中直接修改内容。
那么为了得到正确结果,有没有可行的方式呢?
答案是肯定的,对应上面使用函数的例子,可以使用参数字符串进行替换:
// 正确
name = name.replace(/^(.{20})(.*)(.{5})$/g, "$1~$3");
此时替换内容 "$1~$3" 中的 $1 和 $3 是会被当成参数的,内部实现会将其直接替换。
网友回复
为啥所有的照片分辨率提升工具都会修改照片上的图案细节?
js如何在浏览器中将webm视频的声音分离为单独音频?
微信小程序如何播放第三方域名url的mp4视频?
ai多模态大模型能实时识别视频中的手语为文字吗?
如何远程调试别人的chrome浏览器获取调试信息?
为啥js打开新网页window.open设置窗口宽高无效?
浏览器中js的navigator.mediaDevices.getDisplayMedia屏幕录像无法录制SpeechSynthesisUtterance产生的说话声音?
js中mediaRecorder如何录制window.speechSynthesis声音音频并下载?
python如何直接获取抖音短视频的音频文件url?
js在浏览器中如何使用MediaStream与MediaRecorder实现声音音频多轨道混流?