Review: HTML with Superpowers
Notes
A talk on web components from Dave Rupert (Oct. 2021)
Web components let you make your own elements
They're encapsulated which makes them like Lego blocks
Originally pitched in 2011, but took a long time to get out.
A set of web standards instead of being a custom designed framework (like angular, react, etc...)
Made up of four standards:
HTML
Custom Elements
Shadow DOM
ES Modules (originally HTML Imports but Mozilla killed that approach)
Custom elements have to have a hyphen in them e.g. `custom-element``
Shadow DOM is what provides encapsulation which is what lets the custom element from unintentionally effecting or having an effect on stuff outside it
Mozilla killed HTML Imports which are not ES Modules
Have a google stat saying 12% of pages loaded in chrome use web components
Reasons they don't get used as much:
Designed at a low level like for framework authors
Not truly supported fully until 2020 which edge got it
Move slower because they are standards based, but that means they are much more likely to work in 5-10 years.
Posits that web components are more like writing regular ol' html than dealing with all the modern framework stuff
Shows to Google Labs "two-up" component for comparing two images
The `
Web components are great for progressive enhancement
Sharing components means we can share accessible ones that are framework independent and don't require build systems
You can put core html tags inside the custom elements and they'll render as is if the component fails to fire for some reason.
Shows a 3D model viewer where you just drop in the component and the link to your .glb file.
Piercing the shadow dom. There's a shadow boundary where somethings go through the boundary and some don't. Can be confusing to figure out what's what.
There's a list of inheritable styles that cross the boundary. Other styles don't.
Most of the ones that do are text and font things
Custom CSS variables *do** get passed. These are a great way to add a styling API if you are authoring the component
There are also Named Shadow Parts.
Named Shadow Parts are setup with a `name`` attribute in the HTML that's in the slog of the component. This turns it into a `part`` that a css selector can hit
Code
:;
} )
Every component has a life cycle
(Those are all libraries though, which I'm not as big a fan of because it puts your code on someone else's foundation)
I'm assuming it saves you some significant effort to use one of the libraries, but I'm unclear how much
There's a `::slotted(*)`css` selector inside the Lit library. Not sure if that's for web components in general or Lit specifically.
Make sure to do lots of testing if you're using form controls. There are gotchas hiding in there.
ElementInternals is helping with the form stuff along with formdata
Possibility that if we get good custom elements they eventually become native elements
Links
Generic Components from Pascal Schilp as an example of some good stuff. (You've got a fork of the repo)
Open Web Components that "provides guides, tools and libraries for developing web components. Something that Pascal links to.
Custom Elements Everywhere for details on framework inter-operatibilty
A-Frame a 3D virtual scene builder. For doing WebVR stuff
Stencil Lets you transpile out to various frameworks
is designed to make it easier to write web components.
is another one for making web components
Awesome Standalones which is a collection of web component stuff they put together.
Getting some Web Component knowledge from Dave Rupert