Web Components
by @leocaseiro
data:image/s3,"s3://crabby-images/ac2ba/ac2baa21ff89561009954347edde07b7f5249425" alt=""
slides.com/leocaseiro/web-components
Leo + case + iron
slides.com/leocaseiro/web-components
Another JS Framework?
data:image/s3,"s3://crabby-images/6a511/6a511865a7bb1f10ae8f3a349d0768e29cb509ad" alt=""
slides.com/leocaseiro/web-components
State of JS (Interested)
data:image/s3,"s3://crabby-images/48b33/48b339a7e92efcac3e4b337880ecec0d9cdc5d5b" alt=""
slides.com/leocaseiro/web-components
data:image/s3,"s3://crabby-images/c7f5f/c7f5f57c00d4ec6ae256f0ff22bb7f087202bda3" alt=""
slides.com/leocaseiro/web-components
Why React is so popular?
- Reusable components
- Easy to get started
- Browser support (IE8)
- Performance
slides.com/leocaseiro/web-components
JSConfUS 2013
Tom Occhino and Jordan Walke: JS Apps at Facebook
Things we accept in React
- Compile (Webpack/Babel/Parcel)
- JSX (htmlFor, className, ...junk)
- CSS in JS (hashes)
- Can't use outside React
hate
slides.com/leocaseiro/web-components
In Jun 2015, I was using SMACSS
Scalable Modular Architecture for CSS
smacss.com
slides.com/leocaseiro/web-components
slides.com/leocaseiro/web-components
data:image/s3,"s3://crabby-images/87d68/87d686317442fa29d20385aeb1135ceac0ae98f6" alt=""
slides.com/leocaseiro/web-components
React: CSS in your JS by Christopher Chedeau
slides.com/leocaseiro/web-components
data:image/s3,"s3://crabby-images/6f6ee/6f6eec6727ff3bd232841d0862af69876902ffcc" alt=""
Answer: CSS in JS
SHADOW DOM
slides.com/leocaseiro/web-components
What is Shadow DOM?
data:image/s3,"s3://crabby-images/99bf8/99bf84658e234d45210ee7c40590acecacf2c4b0" alt=""
slides.com/leocaseiro/web-components
- Isolated DOM: A component's DOM is self-contained (e.g. document.querySelector() won't return nodes in the component's shadow DOM).
- Scoped CSS: CSS defined inside shadow DOM is scoped to it. Style rules don't leak out and page styles don't bleed in.
- Composition: Design a declarative, markup-based API for your component.
- Simplifies CSS - Scoped DOM means you can use simple CSS selectors, more generic id/class names, and not worry about naming conflicts.
- Productivity - Think of apps in chunks of DOM rather than one large (global) page.
slides.com/leocaseiro/web-components
slides.com/leocaseiro/web-components
Shadow DOM Tree
data:image/s3,"s3://crabby-images/93395/9339584e941d4d921ecad3eda9c99e404d1f6cd7" alt=""
Shadow DOM example
data:image/s3,"s3://crabby-images/1e757/1e757905304cb8d724ce9c8e9b67649cf12d0a85" alt=""
slides.com/leocaseiro/web-components
A Guide to Working with Shadow DOM using Selenium
slides.com/leocaseiro/web-components
CSS in JS Libraries 2020
- Aphrodite
- Emotion
- Glamor
- Glamorous (dead)
- Fela
- JSS
- Linaria
- Radium
- Styled components
- Styletron
slides.com/leocaseiro/web-components
CSS in JS 2020
using Shadow DOM
data:image/s3,"s3://crabby-images/b60cc/b60cc9ea94f9ca02223e641e895fbf6b7bf123e5" alt=""
attachShadow
ShadowRoot
slides.com/leocaseiro/web-components
Shadow DOM
styled-components HACK
data:image/s3,"s3://crabby-images/ace43/ace435513e1462f6062882800a7a4a81662d8fa6" alt=""
slides.com/leocaseiro/web-components
Web Components
data:image/s3,"s3://crabby-images/ac2ba/ac2baa21ff89561009954347edde07b7f5249425" alt=""
HTML Templates
slides.com/leocaseiro/web-components
Custom Elements
Shadow DOM
Custom Element
class WordCount extends HTMLElement {
constructor() {
// Always call super first in constructor
super();
// Element functionality written in here
}
}
slides.com/leocaseiro/web-components
Custom Element
class WordCount extends HTMLParagraphElement {
// ...
}
customElements.define('word-count', WordCount, { extends: 'p' });
<word-count></word-count>
slides.com/leocaseiro/web-components
Custom Elements
Lifecycle callbacks
- connectedCallback()
- disconnectedCallback()
- adoptedCallback()
Invoked component is moved to a new document.
- attributeChangedCallback()
Invoked added, removed, or changed.
slides.com/leocaseiro/web-components
slides.com/leocaseiro/web-components
update.onclick = function() {
// Randomly update square's attributes
square.setAttribute('l', random(50, 200));
square.setAttribute('c', `rgb(${random(0, 255)}, ${random(0, 255)}, ${random(0, 255)})`);
};
Shadow DOM
// Create a shadow root
var shadow = this.attachShadow({ mode: 'open' });
// Create some CSS to apply to the shadow dom
var style = document.createElement('style');
style.textContent = `
.custom {
color: red
}
`;
// attach the created elements to the shadow dom
shadow.appendChild(style);
slides.com/leocaseiro/web-components
Shadow DOM example
data:image/s3,"s3://crabby-images/1e757/1e757905304cb8d724ce9c8e9b67649cf12d0a85" alt=""
slides.com/leocaseiro/web-components
HTML Templates
<template id="my-paragraph">
<p>My paragraph</p>
</template>
let template = document.getElementById('my-paragraph');
let templateContent = template.content;
document.body.appendChild(templateContent);
slides.com/leocaseiro/web-components
slides.com/leocaseiro/web-components
slides.com/leocaseiro/web-components
Live Code
data:image/s3,"s3://crabby-images/1b7c9/1b7c91e1b06997f13dad2f5b24387d3b61f0b361" alt=""
slides.com/leocaseiro/web-components
Web Components
App Demo
slides.com/leocaseiro/web-components
slides.com/leocaseiro/web-components
TODO App Examples
slides.com/leocaseiro/web-components
Convert React into Web Components
Create Web Components using React
slides.com/leocaseiro/web-components
Conclusion
Be aware, that popular languages and libraries get replaced
iframes, table layouts, css float layout, ...
slides.com/leocaseiro/web-components
- Visual Basic
- ASP3
- PHP
- ActionScript (Flash)
- Silverlight
- Ajax
- XML
- jQuery
- GruntJS
- Gulp
- AngularJS
References
slides.com/leocaseiro/web-components
Questions?
slides.com/leocaseiro/web-components
data:image/s3,"s3://crabby-images/30368/3036863515508bd881d1e488f4bbc12afa058d48" alt=""
slides.com/leocaseiro/web-components
Web Components
By Leo Caseiro
Web Components
- 1,177