我正在处理一些在运行时创建的html,我需要在Javascript中使用正则表达式获取文本。该 html 有一个编辑框,其中包含一些文本和一个图像标记,如下所示:
<img src="http://server/directory/subdirectory/Images1/logo_aa.png" alt=" logo_ce" data-tag=" [[image: logo_aa]] ">
我需要能够提取“[[image: logo_aa]]”部分,然后用它替换整个 html 图像标签。但是或者出于某种原因,当我运行正则表达式时,它只得到“a]”。这是我正在使用的代码示例:
var imgHtmlPattern = new RegExp("<img[^>]*?>", "g");
var imageTagPattern = new RegExp("\[\[Image:\s\S+\]\]", "i");
var str = 'A whole paragraph of text here. <img src="http://server/directory/subdirectory/Images1/logo_aa.png" alt=" logo_ce" data-tag=" [[image: logo_aa]] ">';
var matches = str.match(imgHtmlPattern);
for (i = 0; i < matches.length; i++) {
var test = imageTagPattern.exec(matches[i]);
alert(test);
// var tag = matches[i].match(imageTagPattern);
// alert(tag);
}
var imageTagPattern = new RegExp("[[Image:\s\S+]]", "i");
最佳答案
您需要使用双 \\
来创建 RegExp
对象:
var imageTagPattern = new RegExp("\\[\\[Image:\\s\\S+\\]\\]", "i");
或者只使用正则表达式文字:
var imageTagPattern = /\[\[Image:\s\S+\]\]/i;
关于Javascript正则表达式提取括号中的内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27968623/