[Declarative Shadow DOM Style Sharing] Is DSD the right primitive for reusing component templates? #885
Description
The proposal describes a mechanism for repeating a template across multiple elements in the documents. Reproducing the relevant example below:
<template type="module" specifier="/foo.html">
<!-- This template defines an HTML module whose contents are given by the markup
placed here, inserted into the module map with the specifier "/foo.html" -->
...
</template>
<my-element>
<!-- The `shadoowroothtml` attribute causes the `<template>` to populate the shadow root by
cloning the contents of the HTML module given by the "/foo.html" specifier, instead of
parsing HTML inside the <template>. -->
<template shadowrootmode="open" shadowrootadoptedstylesheets="/foo.css" shadowroothtml="/foo.html"></template>
</my-element>
I'm on board with the general idea here, but this couples the use case of repeating a template with shadow DOM in a way which I'm not convinced is desirable.
First, all users of this must use shadow DOM, which has implications on how styles are authored and linked into the document. Many users may want to repeat a single HTML template without pulling on the baggage of shadow DOM.
Second, I assume slots would still be supported for each usage of a repeated template. That makes a certain amount of sense that static, reusable parts of an element could be shared in a single template while the dynamic pieces can be slotted in via the light DOM like so:
<template type="module" specifier="/foo.html">
<div>Hello, <slot name="username"></slot>! Or would you prefer <slot name="firstname"></slot>?</div>
</template>
<my-element>
<template shadowrootmode="open" shadowroothtml="/foo.html"></template>
<span slot="username">develwithoutacause</span>
<span slot="firstname">Doug</span>
</my-element>
While this static / dynamic separation is useful, it is inherently coupled to the private / public separation of shadow and light DOM. If I want firstname
to be public and replaceable by consumers of my-element
, that's fine. But if I want username
to be private and kept constant from the initial render, then I can't reuse a single static template. Otherwise any consumer of my-element
could replace the <span slot="username">
which exists in the light DOM, and I have no way to protect this implementation detail.
I don't have a great solution to this (private slots, parameterized templates?) but this leads me to believe that we have two distinct problems:
- Public vs private DOM
- Dynamic vs static DOM
We have one mechanism in light vs shadow DOM, and solving both problems with that same mechanism inherently couples them together in an undesirable way. This leads me to believe that shadow DOM is not the right primitive for building a repeatable template system and we may want some other abstraction.
(Slightly off-topic: Given that HTML modules is not quite a thing yet, I suspect it would be better to decouple this proposal from that entirely and just focus on reusing styles, dropping shadowroothtml
completely. I definitely have hesitations about adopting anything in that space without stronger signals for HTML modules on their own, but I'm not super involved with web standards, so I'm not an expert on how these proposals actually move through the process.)