无法根据预定义列表替换文本

时间:2018-06-02 14:41:39

标签: javascript arrays replace replaceall

我正在尝试根据预先定义的搜索词列表及其应替换的内容,创建一个替换一组代码中特定字符串的函数,

render = (data,list) => {
let temp = data;
  for(let i in list){
    temp.split(i).join(list[i]);
   //temp.replace(new RegExp(i, 'g'), list[i]); even this doesn't work
  }
return temp;
}
let test = render("<h1>a1</h1>",
 { "a1" : "Hello World" });

我没有看到任何错误,它只是不替换任何内容并返回原始数据,如果我单独使用用于替换的代码并手动放置在regExp中的值或拆分连接函数,它工作正常..

//修改

预期的输入和输出应为,

let temp = "<h1> $1 </h1>";
console.log( render(test, { "$1":"Hello World" } ) );

这应该输出,

<h1> Hello World </h1>

但我改为

<h1> $1 </h1>

原样。

1 个答案:

答案 0 :(得分:2)

此处的解决方案 -

&#13;
&#13;
render = (data, list) => {
  let temp = data;
  for (let i in list) {
    temp = temp.replace(new RegExp(i, 'g'), list[i]);
  }
  return temp;
}
let test = render("<h1>a1</h1>", {
  "a1": "Hello World"
});

console.log(test);
&#13;
&#13;
&#13;