the most famous
client-side
projects
are fated
to die
Slide 11
Slide 11 text
No content
Slide 12
Slide 12 text
No content
Slide 13
Slide 13 text
No content
Slide 14
Slide 14 text
so you think
everything will
become “native"
one day?
Slide 15
Slide 15 text
what the
major web
companies
have been
working on?
Slide 16
Slide 16 text
No content
Slide 17
Slide 17 text
No content
Slide 18
Slide 18 text
No content
Slide 19
Slide 19 text
No content
Slide 20
Slide 20 text
No content
Slide 21
Slide 21 text
No content
Slide 22
Slide 22 text
No content
Slide 23
Slide 23 text
No content
Slide 24
Slide 24 text
No content
Slide 25
Slide 25 text
No content
Slide 26
Slide 26 text
No content
Slide 27
Slide 27 text
No content
Slide 28
Slide 28 text
No content
Slide 29
Slide 29 text
how do you
create a
“component”
nowadays?
Slide 30
Slide 30 text
1. Never create! Just use a jQuery plugin
Slide 31
Slide 31 text
2. Copy and paste someone’s code
Slide 32
Slide 32 text
3. And hope it works
Slide 33
Slide 33 text
No content
Slide 34
Slide 34 text
Slide 35
Slide 35 text
eduardolundgren.github.io/video-camera-element
Slide 36
Slide 36 text
No content
Slide 37
Slide 37 text
No content
Slide 38
Slide 38 text
// content goes here
Slide 39
Slide 39 text
// content goes here
Slide 40
Slide 40 text
No content
Slide 41
Slide 41 text
using JS
var proto = Object.create(HTMLElement.prototype);
proto.createdCallback = function() {
this.textContent = ‘HTML5 LA!';
};
document.register(‘html5-la', {
prototype: proto
});
how to use it?
// 1. Access template’s content
var t = document.querySelector('#myTemplate').content;
// 2. Manipulate internal element
t.querySelector('img').src = 'logo.png';
// 3. Clone and append in the DOM
document.body.appendChild(t.cloneNode(true));
Slide 57
Slide 57 text
No content
Slide 58
Slide 58 text
Shadow DOM
hides the
implementation
details
Slide 59
Slide 59 text
what about
?
Slide 60
Slide 60 text
what’s a
made of?
or password, textarea, date?
Slide 61
Slide 61 text
how to use it?
Foo
var elem = document.querySelector(‘#elem');
var elemShadowDOM = elem.createShadowRoot();
!
elemShadowDOM.innerHTML = '
Bar
';
Slide 62
Slide 62 text
markup, style &
script encapsulated
Foo
var elem = document.querySelector(‘#elem');
var elemShadowDOM = elem.createShadowRoot();
!
elemShadowDOM.innerHTML = ‘
Bar
’ +
‘h1 { color: red; }’;
Slide 63
Slide 63 text
No content
Slide 64
Slide 64 text
No content
Slide 65
Slide 65 text
No content
Slide 66
Slide 66 text
how to use it?
Slide 67
Slide 67 text
No content
Slide 68
Slide 68 text
No content
Slide 69
Slide 69 text
No content
Slide 70
Slide 70 text
No content
Slide 71
Slide 71 text
where can I
find them?
NPM? Bower?
Slide 72
Slide 72 text
No content
Slide 73
Slide 73 text
No content
Slide 74
Slide 74 text
No content
Slide 75
Slide 75 text
zenorocha.github.io/twitter-button
Slide 76
Slide 76 text
eduardolundgren.github.io/google-maps-element
Slide 77
Slide 77 text
eduardolundgren.github.io/video-camera-element
Slide 78
Slide 78 text
eduardolundgren.github.io/video-tracking-element
Slide 79
Slide 79 text
in other words…
Slide 80
Slide 80 text
encapsulation
and code reuse
for real
Slide 81
Slide 81 text
the best
way to
predict the
future is
to create it