我有一个带有 HTML 模板的Handlebars.js模板,用于在内部创建声明性影子 DOM(由于实际情况较大,因此需要):
<script id="templatePreview" type="text/x-handlebars-template">
<ul>
{{#.}}
<li>
<template shadowroot="open">
{{name}}
</template>
</li>
{{/.}}
</ul>
</script>
由于某些奇怪的原因,它不会在最新的 Chrome (v91) 或 Firefox (v89) 中使用 jQuery(v3.5.x 或最新的 3.6.x)呈现:
<script>
const data = [{
name: "John"
},
{
name: "Peter"
},
{
name: "Mark"
},
];
$(function() {
let templatePreview = Handlebars.compile($('#templatePreview').html());
$("#main").append(templatePreview(data));
});
</script>
这是一个测试 JS bin:https ://jsbin.com/bocenoqovi/edit?html,js,output
Chrome DevTools 控制台显示以下消息,但我不确定如何解决此问题:
Found declarative shadowroot attribute on a template, but declarative Shadow DOM has not been enabled by includeShadowRoots.