Следующее регулярное выражение должно найти все совпадения ${any expression}
, код выглядит следующим образом:
const reg= /\$\{[^]+\}/g
let txt= '`${i + " test"} RESULT ${2 + 4} now ${i} hi`'
let result= [...txt.matchAll(reg)];
console.log(result)
Как вы заметили, в результате извлекается почти вся строка, правильная операция должна вывести в консоль массив из 3 элементов, который будет содержать ${any expression}
В следующем случае показана ошибка, которая возникает, если я использую: [^}]
const reg= /\$\{[^}]+\}/g
let i= "some"
let txt= `${i + " test"} RESULT ${2 + 4} now ${i + "}" } hi`
let txtString= '`${i + " test"} RESULT ${2 + 4} now ${i + "}" } hi`'
let result= [...txtString.matchAll(reg)];
console.log(result)
console.log(txt)
выражение ${i + "}" }
допустимо в JavaScript, поэтому регулярное выражение должно возвращать [${i + "}" }, other matches]
, но в показанном примере оно возвращает
${i + "}
Если вы пытаетесь реализовать интерпретатор JS, я думаю, что регулярное выражение — не лучший инструмент; Однако, если вы пытаетесь что-то сделать с JS литерал шаблона, вы можете попробовать пометить функцию/помеченный шаблон.
Если вы можете описать синтаксис токена внутри ${...}
, вы все равно можете использовать регулярное выражение.
Если мы предположим, что
${
+
, -
, *
или /
."...\"...\\..."
)}
Затем вы можете использовать
const reg= /\${\s*(?:\w+|"[^"\\]*(?:\\[^][^"\\]*)*")(?:\s*[-+\/*]\s*(?:\w+|"[^"\\]*(?:\\[^][^"\\]*)*"))*\s*}/g
См. демонстрация регулярных выражений.
См. демонстрацию JavaScript:
const token = '(?:\\w+|"[^"\\\\]*(?:\\\\[^][^"\\\\]*)*")';
const op = '[-+/*]';
const reg= new RegExp(String.raw`\${\s*${token}(?:\s*${op}\s*${token})*\s*}`, 'g');
let i= "some"
let txt= `${i + " test"} RESULT ${2 + 4} now ${i + "}" } hi`
let txtString= '`${i + " test"} RESULT ${2 + 4} now ${i + "}" } hi`'
let result= [...txtString.matchAll(reg)];
console.log(result)
console.log(txt)
Я боюсь, что регулярные выражения недостаточно мощны, чтобы проанализировать произвольное выражение JavaScript.