HTML 5 представил элемент <template>
, который можно использовать для этой цели (как теперь описано в спецификациях WhatWG и MDN ).
A <template>
- это HTML-элемент, который допускается для любого другого типа элемента в качестве дочернего. У template
есть свойство .content
, к которому вы можете обратиться с помощью JavaScript, что указывает на DocumentFragment
с содержимым шаблона. Это означает, что вы можете преобразовать строку HTML в элементы DOM, установив innerHTML
элемента <template>
, а затем перейдя в свойство template
'.content
.
Примеры:
/**
* @param {String} HTML representing a single element
* @return {Element}
*/
function htmlToElement(html) {
var template = document.createElement('template');
html = html.trim(); // Never return a text node of whitespace as the result
template.innerHTML = html;
return template.content.firstChild;
}
var td = htmlToElement('<td>foo</td>'),
div = htmlToElement('<div><span>nested</span> <span>stuff</span></div>');
/**
* @param {String} HTML representing any number of sibling elements
* @return {NodeList}
*/
function htmlToElements(html) {
var template = document.createElement('template');
template.innerHTML = html;
return template.content.childNodes;
}
var rows = htmlToElements('<tr><td>foo</td></tr><tr><td>bar</td></tr>');
Обратите внимание, что подобные подходы, в которых использует другой элемент контейнера, такой как div
, не совсем работают. HTML имеет ограничения на то, какие типы элементов могут существовать внутри каких других типов элементов; например, вы не можете поставить td
как прямой потомок div
. Это приводит к исчезновению этих элементов, если вы попытаетесь установить innerHTML
из div
, чтобы они содержались. Поскольку <template>
s не имеют таких ограничений на их содержимое, этот недостаток не применяется при использовании шаблона.
Однако template
не поддерживается в некоторых старых браузерах. По состоянию на январь 2018 года Могу ли я использовать ... оценки 90% пользователей во всем мире используют браузер, который поддерживает template
s . В частности, ни одна версия Internet Explorer не поддерживает их; Microsoft не реализовала поддержку template
до выхода Edge.
Если вам посчастливилось писать код, предназначенный только для пользователей в современных браузерах, используйте его прямо сейчас. В противном случае вам, возможно, придется подождать некоторое время, чтобы пользователи наверстали упущенное.