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

failing to replace text according to a predefined list

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

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" });

我没有看到任何错误,它只是没有替换任何东西和 returns 原始数据,如果我单独使用用于替换的代码并手动将值放入regExp 或 split join 函数,它工作正常..

//编辑

预期的输入和输出应该是,

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

这是应该输出的,

<h1> Hello World </h1>

但我却得到了

<h1>  </h1>

原样。

这是解决方案 -

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);