javascript – RegEx内部的模板文字
作者:互联网
我试图在RegEx中放置一个模板文字,但它不起作用.然后我创建了一个变量正则表达式,它保存了我的RegEx,但它仍然没有给我想要的结果.
但是,如果我单独调试console.log(正则表达式),我会收到所需的RegEx,例如/. ?(?=位置)/ i,/. ?(?= date)/ i等等,但是一旦我将正则表达式置于.replace内部,它似乎无法正常工作
function validate (data) {
let testArr = Object.keys(data);
errorMessages.forEach((elem, i) => {
const regex = `/.+?(?=${elem.value})/i`;
const a = testArr[i].replace(regex, '');
})
}
解决方法:
你的正则表达式变量是一个字符串.要使其成为RegExp,请使用
const regex = new RegExp(`.+?(?=${elemvalue.replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&')})`, "i");
另外,在正则表达式中使用escape the variable部分是一个好主意,因为所有特殊的正则表达式元字符都被视为文字.
const s = "final (location)";
const elemvalue = "(location)";
const regex = new RegExp(`.+?(?=${elemvalue.replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&')})`, "i");
// console.log(regex); // /.+?(?=\(location\))/i
// console.log(typeof(regex)); // object
let a = s.replace(regex, '');
console.log(a);
标签:template-literals,javascript,regex 来源: https://codeday.me/bug/20190929/1832448.html