-
Notifications
You must be signed in to change notification settings - Fork 9
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Light DOM children / slots (aka HTML Web Components) #154
Comments
We use Lit to build our editor, and due to the feature of rich text editors, we do not use shadow DOM. Lit is simply used as a way to encapsulate HTML (this seems to be referred to as light DOM, please correct me if I'm wrong). Recently, we are researching SSR for light DOM in order to render a read-only editing page in the browser (similar to Notion's public page). For speed and SEO purposes, we need to render light DOM on the server. Is this issue attempting to address this problem? Do you have any possible suggestions for our scenario?🙏 That's out project: You can click this link to know how we use lit: |
Hey @Flrande 👋 So just making sure I'm looking at the right thing, but if this is an example the what you are you referring to then yes, the For WCC, it supports both because it is a bit more low-level than Lit and so the way you author your WebComponent will determine what WCC server renders out for you when running SSR. So for this usage <app-card
title="Some Title"
thumbnail="image.png"
/>
</app-card> Light DOM Example export default class Card extends HTMLElement {
connectedCallback() {
this.innerHTML = `
<style>
/* ideally you would use a global styling solution instead of an inline style tag */
</style>
<div>
<h3>${title}</h3>
<img src="${thumbnail}" alt="${title}" loading="lazy" width="100%">
</div>
`;
}
}
customElements.define('app-card', Card); Will output <app-card>
<style>
/* ideally you would use a global styling solution instead of an inline style tag */
</style>
<div>
<h3>Some Title</h3>
<img src="image.png" alt="Some Title" loading="lazy" width="100%">
</div>
</app-card> (Declarative) Shadow DOM Example export default class Card extends HTMLElement {
connectedCallback() {
if (!this.shadowRoot) {
const thumbnail = this.getAttribute('thumbnail');
const title = this.getAttribute('title');
const template = document.createElement('template');
template.innerHTML = `
<style>
/* ... */
</style>
<div>
<h3>${title}</h3>
<img src="${thumbnail}" alt="${title}" loading="lazy" width="100%">
</div>
`;
this.attachShadow({ mode: 'open' });
this.shadowRoot.appendChild(template.content.cloneNode(true));
}
}
}
customElements.define('app-card', Card); Will output <app-card>
<template shadowrootmode="open">
<style>
/* ideally you would use a global styling solution instead of an inline style tag */
</style>
<div>
<h3>Some Title</h3>
<img src="image.png" alt="Some Title" loading="lazy" width="100%">
</div>
</template>
</app-card> This particular feature is more around exploring a use case where providing content to a WC may be more ergonomic to do through HTML tags instead of attributes (in old AngularJS I think they called this transclusion, in React it would be
This is just for a solution aimed at Light DOM scenarios though, as if you were using Shadow DOM, then Hope that helps and neat project! 🌟 |
Thank you for your response! It looks like we may need to try implementing our own SSR mechanism for Lit that supports light dom, as our components actually rely on many features of Lit that are not available in native Web Components, such as property-expressions. |
@Flrande I think it would definitely be worth sharing your experience in that Discussion thread and / or joining their Discord and reaching out in their #ssr channel. |
Hi @Firande, Just came across this thread and wondering if you figured anything out here? I'm on the same journey where I'm just using lit-html (not LitElement) and am trying to figure out an SSR solution that works for both light-dom and shadow-dom web components while allowing for property-expressions. Thank you in advance! |
Summary
Although primarily a client side / runtime dependent technique, the idea of HTML Web Components, seems like a really nice technique to be able to do in situations where it would be easer to "slot" children in via HTML instead of attributes, in particular for very content heavy scenarios and that could still be done at SSR time.
For comparison
Details
Now this basically relies on doing an
innerHTML
in theconnectedCallback
function, e.g.but if done on the server, could basically allow for any sort of option for handling light DOM children that is still standard compliant, especially in conjunction with something like ProjectEvergreen/greenwood#1233
I've tested this in the browser and so as long as this doesn't break any test cases, this seems like a legit feature to support?
The text was updated successfully, but these errors were encountered: