timepiece/node_modules/@lit-labs/ssr-dom-shim/README.md

59 lines
2.6 KiB
Markdown
Raw Normal View History

2024-05-14 14:54:12 +00:00
# @lit-labs/ssr-dom-shim
## Overview
This package provides minimal implementations of `Element`, `HTMLElement`,
`CustomElementRegistry`, and `customElements`, designed to be used when Server
Side Rendering (SSR) web components from Node, including Lit components.
## Usage
### Usage from Lit
Lit itself automatically imports these shims when running in Node, so Lit users
should typically not need to directly depend on or import from this package.
See the [lit.dev SSR docs](https://lit.dev/docs/ssr/overview/) for general
information about server-side rendering with Lit.
### Usage in other contexts
Other libraries or frameworks who wish to support SSR are welcome to also depend
on these shims. (This package is planned to eventually move to
`@webcomponents/ssr-dom-shim` to better reflect this use case). There are two
main patterns for providing access to these shims to users:
1. Assigning shims to `globalThis`, ensuring that assignment occurs before
user-code runs.
2. Importing shims directly from the module that provides your base class, using
the `node` [export
condition](https://nodejs.org/api/packages.html#conditional-exports) to
ensure this only happens when running in Node, and not in the browser.
Lit takes approach #2 for all of the shims except for `customElements`, so that
users who have imported `lit` are able to call `customElements.define` in their
components from Node.
### Exports
The main module exports the following values. Note that no globals are set by
this module.
- [`Element`](https://developer.mozilla.org/en-US/docs/Web/API/Element)
- [`attachShadow`](https://developer.mozilla.org/en-US/docs/Web/API/Element/attachShadow)
- [`shadowRoot`](https://developer.mozilla.org/en-US/docs/Web/API/Element/shadowRoot)
- [`attributes`](https://developer.mozilla.org/en-US/docs/Web/API/Element/attributes)
- [`hasAttribute`](https://developer.mozilla.org/en-US/docs/Web/API/Element/hasAttribute)
- [`getAttribute`](https://developer.mozilla.org/en-US/docs/Web/API/Element/getAttribute)
- [`setAttribute`](https://developer.mozilla.org/en-US/docs/Web/API/Element/setAttribute)
- [`removeAttribute`](https://developer.mozilla.org/en-US/docs/Web/API/Element/removeAttribute)
- [`HTMLElement`](https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement)
- (Inherits from Element)
- [`CustomElementRegistry`](https://developer.mozilla.org/en-US/docs/Web/API/CustomElementRegistry)
- [`customElements`](https://developer.mozilla.org/en-US/docs/Web/API/Window/customElements)
## Contributing
Please see [CONTRIBUTING.md](../../../CONTRIBUTING.md).