Шаблонные строки
https://developer.mozilla.org/ru/docs/Web/JavaScript/Reference/Template_literals
Шаблонными литералами называются строковые литералы, допускающие использование выражений внутри. С ними вы можете использовать многострочные литералы и строковую интерполяцию. В спецификациях до ES2015 они назывались "шаблонными строками".
Шаблонные литералы заключены в обратные кавычки (` `) вместо двойных или одинарных. Они могут содержать подстановки, обозначаемые знаком доллара и фигурными скобками (${выражение}
). Выражения в подстановках и текст между ними передаются в функцию. По умолчанию функция просто объединяет все части в строку. Если перед строкой есть выражение (здесь это tag
), то шаблонная строка называется "теговым шаблоном". В этом случае, теговое выражение (обычно функция) вызывается с обработанным шаблонным литералом, который вы можете изменить перед выводом. Для экранирования обратной кавычки в шаблонных литералах указывается обратный слеш \.
Copy to Clipboard
Символы новой строки являются частью шаблонных литералов. Используя обычные строки, вставка переноса потребовала бы следующего синтаксиса:
Copy to Clipboard
То же с использованием шаблонных литералов:
Copy to Clipboard
Для вставки выражений в обычные строки вам пришлось бы использовать следующий синтаксис:
Copy to Clipboard
Теперь, при помощи шаблонных литералов, вам доступен "синтаксический сахар", делающий подстановки вроде той более читабельными:
Copy to Clipboard
Временами, вложить шаблон — это кратчайший и, возможно, более читабельный способ составить строку. Просто поместите внутрь шаблона с обратными кавычками ещё одни, обернув их в подстановку ${ }
. Например, если выражение истинно, можно вернуть шаблонный литерал.
В ES5:
Copy to Clipboard
В ES2015 с шаблонными литералами без вложения:
Copy to Clipboard
В ES2015 с вложенными шаблонными литералами:
Copy to Clipboard
Расширенной формой шаблонных литералов являются теговые шаблоны. Они позволяют разбирать шаблонные литералы с помощью функции. Первый аргумент такой функции содержит массив строковых значений, а остальные содержат выражения из подстановок. В итоге, функция должна вернуть собранную строку (или что-либо совсем иное, как будет показано далее). Имя функции может быть любым.
Copy to Clipboard
Функция тега не обязана возвращать строку, как показано в примере ниже:
Copy to Clipboard
Специальное свойство raw
, доступное для первого аргумента тегового шаблона, позволяет получить строку в том виде, в каком она была введена, без экранирования.
Copy to Clipboard
Вдобавок, существует метод String.raw()
, возвращающий точно такую же исходную строку, какую вернула бы функция шаблона по умолчанию и строковая конкатенация вместе.
Copy to Clipboard
Поведение в ES2016
В ECMAScript 2016 теговые шаблоны следуют правилам экранирования следующих символов:
символы Unicode, начинающиеся с "\u", например,
\u00A9
точки кода Unicode, начинающиеся с "\u{}", например,
\u{2F804}
шестнадцатеричные представления символов, начинающиеся с "\x", например,
\xA9
восьмеричные представления символов, начинающиеся с "\", например,
\251
Отсюда вытекает проблема теговых шаблонов: следуя грамматике ECMAScript, анализатор кода, найдя символ \
, будет искать корректное представление символа Unicode, но может не найти его вовсе. Пример ниже показывает это:
Copy to Clipboard
Поведение в ES2018
Теговые шаблоны должны позволять встраивать языки (например, DSLs или LaTeX), в которых широко используются многие другие экранирования. Предложение Редакция шаблонных литералов (уровень 4, одобренный к добавлению в стандарт ECMAScript 2018) устраняет синтаксические ограничения экранирования теговых шаблонов в ECMAScript.
Однако, некорректное экранирование символов по-прежнему нужно отображать в "приготовленном" отображении. Оно показывается в виде undefined
в "приготовленном" массиве:
Copy to Clipboard
Заметьте, что ограничение на экранирование символов проявляется лишь в теговых шаблонах, и не проявляется в нетеговых шаблонных литералах:
Last updated