Web Components
con Stencil
BeerJS N° 27
Córdoba, 21 de Febrero de 2019
< />
@joelalejandro
¿Web Components?
¿Shadow DOM?
¿Custom Elements?
¿Polymer?
¿React?
Librería de UI
Encapsulamiento
Set de APIs
API de registro
Librería de CE
class MyComponent
extends HTMLElement {
}
Estructura mínima viable de un Web Component.
window.customElements.register(
"my-component",
MyComponent
);
<my-component />
Esto es todo lo que necesitás
para renderizar un Web Component.
Vamos a crear nuestro componente de botón,
basado en Material Design. (*)
.
.
.
(acá el speaker tiene que mostrar su IDE)
.
.
.
¿Algo más rápido?
¿Observers?
¿Pre-rendering?
¿Reactiveness?
¿State?
Un compilador
de Web Components
(utilizando TypeScript)
npm init stencil
Todo comienza así (*)
(*) = npm@^6
.
.
.
(acá el speaker tiene que mostrar su IDE)
.
.
.
Custom Elements API
Polyfills para todo
One-way Data Binding
Async rendering
TypeScript + JSX
Pre-rendering
Unit + E2E Tests
PWA
import { Component, Event, EventEmitter, Prop } from "@stencil/core";
@Component({
tag: "form-button",
styleUrl: "form-button.scss",
shadow: true
})
export class FormButton {
@Event() buttonPressed: EventEmitter;
@Prop() disabled: boolean;
handleClick(e) {
e.preventDefault();
this.buttonPressed.emit(e);
}
render() {
return (
<button
disabled={this.disabled}
onClick={this.handleClick.bind(this)}
class="button"
>
<slot />
</button>
);
}
}
Component Decorator
Event Delegation
JSX
Template
Props
¡Stencil se lleva
bien con todos!
Los distribuibles de Stencil están basados 100% en APIs nativas, sin ataduras a ningún framework o librería.
<!doctype html>
<html>
<head>
<meta charset="utf-8" />
<title>My App</title>
</head>
<body>
<material-button
color="black"
onClick="alert('Hola, BeerJS!')">
Dame un click
</material-button>
<script src="components/material-button.js"></script>
</body>
</html>
Stencil Design Systems
¿preguntas?
Web Components
con Stencil
BeerJS N° 27
Córdoba, 21 de Febrero de 2019
< />
@joelalejandro
¡Gracias!
<Web Components con Stencil />
By Joel Alejandro Villarreal Bertoldi
<Web Components con Stencil />
Estado actual de Web Components. Live demos con Vanilla JS y Stencil.
- 614