搜索/将自定义标记替换为 javascript 正则表达式

Search/Replace a custom marker with javascript regex

本文关键字:替换 javascript 正则表达式 自定义 搜索      更新时间:2023-09-26

在文本字符串中,我想查找任何出现的[[mymarker-id]]并将其替换为自定义html字符串:

'<div>id</div>'

例如:

"this is a sample text [[mymarker-123_4Efd]] for illustration purpose"

会成为

"this is a sample text <div>123_4Efd</div> for illustration purpose"

ID 为 8 个字符长的字符串匹配:([a-zA-Z0-9_-]){8}

我希望我可以说我在问之前尝试了很多事情,但我对正则表达式很糟糕

捕获 8 个字符的长Id,并将自定义 HTML 中的Id替换为捕获的文本。

var marker = "this is a sample text [[mymarker-123_4Efd]] for illustration purpose"
marker.replace(/'['[mymarker-(.{8})']']/, '<div>$1</div>')

或者,如果自定义 HTML 是动态构造的:

var customHtml = '<div>id</div>';
var id = marker.match(/'['[mymarker-(.{8})']']/)[1];
customHtml = customHtml.replace('id', id);

jsBin 演示

使用此正则表达式:

'['[mymarker'-([^']]+)']']
var str   = "this is a sample text [[mymarker-123_4Efd]] for illustration purpose";
var regex = /('['[mymarker'-)([^']]+)']']/;
str = str.replace(regex, "<div>$2</div>");
    var re = /'['[mymarker-123_4Efd']']/gi;
    var str = "this is a sample text [[mymarker-123_4Efd]] for illustration purpose";
    var newstr = str.replace(re, "<div>123_4Efd</div>");
    console.log(newstr);

必须使用反斜杠转义 [ 和 ] 符号