Web Components
The Modular for frontend
What
did you
feeling?
data:image/s3,"s3://crabby-images/3a4f3/3a4f3110fd9cff24d1e72d41beacad354c786f78" alt=""
Too many tags needed.
Rendering as your browser
data:image/s3,"s3://crabby-images/2e601/2e6015f175c043498409babc2b8a42969966666a" alt=""
data:image/s3,"s3://crabby-images/5f78e/5f78eba922e5702fe27eb7324b20af7bf9bc2cae" alt=""
Managed Elements?
FXCK YEAH!
data:image/s3,"s3://crabby-images/6b714/6b71477900c39fa4fdbbe0b4e1b0d1f15eacf334" alt=""
You will need
THIS.
You will need
THIS.
data:image/s3,"s3://crabby-images/47e18/47e1897549d523eb44ad1aa4ef12b03b5554fd5e" alt=""
How to use
WEB COMPONENTS?
<template>
<div class="slide">
<ul>
<content select="li"></content>
</ul>
</div>
</template>
1. Template
<decorator id="details-open">
<template>
<a id="summary">
▾
<content select="summary"></content>
</a>
<content></content>
</template>
</decorator>
2. Decorator
details[open] {
decorator: url(#details-open);
}
<details open>
<summary>Timepieces</summary>
<ul>
<li>Sundial
<li>Cuckoo clock
<li>Wristwatch
</ul>
</details>
<element name="x-slide" extends="ul" constructor="SlideControl">
<template>
<div class="slide">
<ul>
<content select="li"></content>
</ul>
</div>
</template>
<script>
SlideControl.prototype = {
currentNum : function(){},
lastNum : function(){}
}
this.lifecycle({
created: function(root) {}
});
</script>
</element>
3. Custom Elements
<x-slide is="x-slide">
<li><img src="http://helloworld.naver.com/img/1.jpeg" alt="1.jpeg" width="500px" height="333px" style=""></li>
<li><img src="http://helloworld.naver.com/img/2.jpeg" alt="2.jpeg" width="500px" height="333px" style=""></li>
<li><img src="http://helloworld.naver.com/img/3.jpeg" alt="3.jpeg" width="500px" height="333px" style=""></li>
<li><img src="http://helloworld.naver.com/img/4.jpeg" alt="4.jpeg" width="500px" height="333px" style=""></li>
</x-slide>
data:image/s3,"s3://crabby-images/59e48/59e483b876da548e11919d9d36112b275c2f7418" alt=""
Hell yeah!
Shadow DOM
Shadow DOM
Shadow DOM
Before shadow coming...
After shadow coming...
Shadow in shadow...
data:image/s3,"s3://crabby-images/448b5/448b5ded695b45e62ed6559b37f85f094671d8c4" alt=""
Shadow DOM
Usage
data:image/s3,"s3://crabby-images/463d6/463d6358ee65c3a6210e539fee0a90d57d0acc98" alt=""
SVG
data:image/s3,"s3://crabby-images/cec81/cec815a3ed59ea42e87d81ac507ad8253479563b" alt=""
data:image/s3,"s3://crabby-images/4a2a6/4a2a64a8dbf87304aa0f36f05204b6351cc9c18d" alt=""
Web App Modulization
"SI" SUXKS
Web components
make easier your life.
Polymer
data:image/s3,"s3://crabby-images/faa41/faa41c080fe04d365d008fd0c50cfb4e876ca8f4" alt=""
X-tag
xtag.register('x-clock', {
lifecycle: {
created: function(){
this.start();
}
},
methods: {
start: function(){
this.update();
this.xtag.interval = setInterval(this.update.bind(this), 1000);
},
stop: function(){
this.xtag.interval = clearInterval(this.xtag.interval);
},
update: function(){
this.textContent = new Date().toLocaleTimeString();
}
},
events: {
tap: function(){
if (this.xtag.interval) this.stop();
else this.start();
}
}
});
Bosonic
data:image/s3,"s3://crabby-images/faf01/faf01b31e1a7662aaafceaa1a923521c74286371" alt=""
<style>
b-dropdown.modern {
border: 1px solid #ccc;
}
b-dropdown.modern > button {
background-color: #ccc;
}
</style>
<b-dropdown class="modern">
<button>Dropdown</button>
<ul>
<li>plain text</li>
<li><a href="#">link item</a></li>
<hr />
<li><a href="#">separated link</a></li>
</ul>
</b-dropdown>
Any Questions?
NO?
TANK YOU
COMPOSITE
Ukjin Yang
HTML5 Freelancer.
Dazare Manager
data:image/s3,"s3://crabby-images/61bee/61bee16c7a71c593eadb9485931431af046655d5" alt=""
data:image/s3,"s3://crabby-images/c6d4c/c6d4c7621d331f8a53f492cf9fd3f8182389c9c6" alt=""
Did you forget something, speaker?
Don't forget imports!
<link rel="import" href="goodies.html">
data:image/s3,"s3://crabby-images/bb7a9/bb7a95b6ebf454240cde24392e1553cbd2a7af9a" alt=""
True Story
데단한 기능!
Amazing Function!
Web Component
By Ukjin Yang
Web Component
- 1,060