Web components
as a compile target
data:image/s3,"s3://crabby-images/bfb89/bfb893e2a2703e96d0c5f8b3a838e3d2d8666f51" alt=""
Andrei Antal
BucharestJS Meetup
21.02.2018
The state of modern frontend frameworks
data:image/s3,"s3://crabby-images/04ac8/04ac81b12ab6c0c7100c78fad31f0e9827c43253" alt=""
data:image/s3,"s3://crabby-images/dd892/dd892a57ec5f9f7b5568298ffa8ee5b27485cced" alt=""
data:image/s3,"s3://crabby-images/b6a37/b6a37c538b6d3d81321e282db7a12e167493e25e" alt=""
Ideal for building complete, SPA apps...
...but difficult to use outside their context
data:image/s3,"s3://crabby-images/e7b84/e7b843e86de1e38d01efe410da8a1351d4d0027e" alt=""
Can we do better?
A set of 4 standard specifications:
- HTML Templates
- Shadow DOM
- HTML Imports
- Custom Elements
WEB COMPONENTS
data:image/s3,"s3://crabby-images/bfb89/bfb893e2a2703e96d0c5f8b3a838e3d2d8666f51" alt=""
A set of 4 standard specifications:
- HTML Templates
- Shadow DOM
- HTML Imports
- Custom Elements
WEB COMPONENTS
<template>
<h1> Hello <h1>
<div>
...content
</div>
</template>
A set of 4 standard specifications:
- HTML Templates
- Shadow DOM
- HTML Imports
- Custom Elements
WEB COMPONENTS
<my-app>
<#shadow-root>
<div class="main">
<h1 class="title">
Hello
</h1>
...
<div>
</shadow-root>
</my-app>
A set of 4 standard specifications:
- HTML Templates
- Shadow DOM
- HTML Imports
- Custom Elements
WEB COMPONENTS
<html>
<head>
<link
rel="import"
href="file.html">
</link>
</head>
</html>
A set of 4 standard specifications:
- HTML Templates
- Shadow DOM
- HTML Imports
- Custom Elements
WEB COMPONENTS
<my-app>
<custom-header />
<main-content />
</my-app>
WEB COMPONENTS
<body>
....
<my-datepicker date="02/02/2018"></my-datepicker>
...
</body>
Encapsulates
- template (structure)
- styles
- logic
Exposes:
- attributes/properties
- bindable events
const myPicker = document.querySelector('my-dateicker');
elem.addEventListener('date-change', ev => { /* change */});
WEB COMPONENTS
data:image/s3,"s3://crabby-images/1a40d/1a40d4cf5d1aea6aa953299e6d6914d7abdd8a49" alt=""
WEB COMPONENTS
data:image/s3,"s3://crabby-images/9a282/9a2824fabe7c7d94dcb190ee6640271b9a21b46c" alt=""
data:image/s3,"s3://crabby-images/7efeb/7efeba4de25bd250b9bff6fade94305bd3b995e2" alt=""
The good
- Open source, cross-platform UI framework
- Based 100% on web technologies (HTML5, CSS, JS)
- Used to develop Native mobile apps, alongside Cordova
The not so good
- Only uses Angular
- Big bundles - problematic for websites or PWA
data:image/s3,"s3://crabby-images/af329/af3297ad6f6dc19d0dc954463e669dc0b894b1c5" alt=""
What is it?
- Stencil is a compiler that generates Web Components (Custom elements)
- Some features:
- Written in TypeScript
- Uses Virtual DOM
- Async rendering (inspired by React Fiber)
- Reactive data-binding
- JSX for templating
data:image/s3,"s3://crabby-images/af329/af3297ad6f6dc19d0dc954463e669dc0b894b1c5" alt=""
import { Component, Prop, Event, Listen } from '@stencil/core';
@Component({
tag: 'my-component',
styleUrl: 'my-first-component.scss'
})
export class MyComponent {
@Prop() name: string;
@Event() someEvent: EventEmitter;
@Listen('someEvent')
eventHandler(event: CustomEvent) { ... }
render() {
return <p>
Hello {this.name}
</p>
}
}
<my-component name="World"></my-component>
A simple component
data:image/s3,"s3://crabby-images/2510b/2510b06601a7d3ebc171f523f7ca9ead8b43dd90" alt=""
data:image/s3,"s3://crabby-images/5983c/5983cedc33a4dd08e6b12536081129a9ef774c36" alt=""
Angular Elements
data:image/s3,"s3://crabby-images/87b8e/87b8e7176182dbf6742a1d40df36380fe251353d" alt=""
SkateJS
Link to ngEurope 2018 talk: goo.gl/m2JdNU
data:image/s3,"s3://crabby-images/0a232/0a232ad5251eadd30b63e9821588a7fa956bd6b8" alt=""
data:image/s3,"s3://crabby-images/b7c10/b7c103dc52324bbba0791b9166684992fefba077" alt=""
data:image/s3,"s3://crabby-images/81e76/81e7609f44134b94bd4fd6d732f7c41be38ccce5" alt=""
THANK YOU!
BUILD AWESOME SHIT!!
Web components as a compile target
By Andrei Antal
Web components as a compile target
BucharestJS February 2018 Meetup Lightning talk - Web Components as a compile target by Andrei Antal
- 1,277