be-evanescent is a web component decorator that removes the element it adorns from the DOM tree when the web component definitions it monitors for become registered.
Size of package, including custom element behavior framework (be-decorated):
Size of new code in this package:
The biggest use case is providing initial css rules for light children, prior to being slotted. This is important for avoiding FOUC. But leaving the styles behind when no longer applicable, could have a lasting negative impact on other light children waiting for their web components to become registered, as well as non-shadowed content. Not to mention the performance impact of having non applicable css sitting in memory.
be-evanescent is an attribute-based alternative to transient-style.
<style be-evanescent='["be-evanescent"]'>
div{
color: red;
}
</style>
The style tag is removed from the DOM tree as soon as web component "be-evanescent" is registered.
- Install git.
- Fork/clone this repo.
- Install node.
- Open command window to folder where you cloned this repo.
-
npm install
-
npm run serve
- Open http://localhost:3030/demo/dev in a modern browser.
<script type=module crossorigin=anonymous>
import 'https://esm.run/be-evanescent';
</script>