@webcomponents/template-shadowroot
TypeScript icon, indicating that this package has built-in type declarations

0.2.1 • Public • Published

Declarative Shadow DOM Ponyfill

Declarative Shadow DOM for SSR

A ponyfill of the API described by Mason Freed at https://github.com/mfreed7/declarative-shadow-dom.

Overview

This package provides a function, hydrateShadowRoots, that converts <template> elements with a shadowrootmode attribute into ShadowRoots on the template's parent element.

This allows HTML with shadow roots to be serialized to plain HTML, and the serialized shadow roots "rehydrated" (separate from component hydration) on the client.

<template shadowrootmode> elements are transformed bottom up so that in the case where they're nested, all elements within the declarative shadow tree stay inert until they have all been moved from their <template shadowrootmode> elements.

If native support for <template shadowrootmode> is present, hydrateShadowRoots does nothing when called.

Known limitations

  • Does not currently look into imperatively created shadow roots.
  • The mutation observer implementation
    • May not work properly in the face of streaming HTML parsing. Needs investigation.
    • Will not notice imperatively created <template shadowrootmode> elements inside of other shadow roots.
  • Not enough benchmarks, and benchmarks of insufficient quality to be confident of good performance.

Dependencies (0)

    Dev Dependencies (9)

    Package Sidebar

    Install

    npm i @webcomponents/template-shadowroot

    Weekly Downloads

    6,207

    Version

    0.2.1

    License

    BSD-3-Clause

    Unpacked Size

    41.5 kB

    Total Files

    33

    Last publish

    Collaborators

    • webcomponents-devs
    • bicknellr
    • azakus
    • aomarks