@eightshapes/slotify
v0.6.1
Published
A class mixin for LitElement that adds <slot> functionality to templates without using the ShadowDOM
Downloads
6
Readme
Slotify
Slotify is a LitElement class mixin that enables <slot>
functionality in templates without requiring the use of ShadowDOM.
It's based on the Vampire Slot Library by @daniel-nagy.
Usage
Install:
npm install @eightshapes/slotify --save
In your LitElement Component:
import { LitElement, html } from 'lit-element';
import { Slotify } from '@eightshapes/slotify';
export class MyCheeseburger extends Slotify(LitElement) {
render() {
return html`
<div class="my-cheeseburger">
<s-slot name="bun-top"></s-slot>
<s-slot name="cheese">DEFAULT CHEESE</s-slot>
<s-slot></s-slot>
<s-slot name="bun-bottom"></s-slot>
<div class="my-cheeseburger__plate">Burger Plate</div>
</div>
`;
}
}
customElements.define('my-cheeseburger', MyCheeseburger);
Then to use the component in HTML:
<script type="module" src="/path/to/compiled/my-cheeseburger.js" />
<my-cheeseburger>
<div slot="bun-bottom">BUN BOTTOM</div>
<div slot="bun-top">BUN TOP</div>
Meat, pickles, lettuce, tomato
<div slot="cheese">CHEESE</div>
</my-cheeseburger>
Details
Use <s-slot>
elements in LitElement templates instead of <slot>
elements. <s-slot>
is a custom element that enables the slot-like functionality via Mutation Observers.
Isn't ShadowDOM the future?
Maybe. I have some thoughts on that. If you decide that ShadowDOM is for you at some point in the future, switching from Slotify to ShadowDOM is easy.
- Unwrap the
Slotify
mixin from yourextends LitElement
declaration. - Replace all the
<s-slot>
instances in your template with<slot>
That's it!
Consumers of your component don't need to change anything, their code will already be compatible with ShadowDOM.