Angular x
Web Components
data:image/s3,"s3://crabby-images/b7fb1/b7fb1385b1f65ae1c355771750d1004bcd72b3ee" alt=""
Suguru Inatomi
data:image/s3,"s3://crabby-images/34d8c/34d8c500b99989d6bb132417b1d96917b42c995c" alt=""
about me
data:image/s3,"s3://crabby-images/59ad1/59ad186996b13c7d47429c6a8a59048a3c0528c4" alt=""
- laco / Suguru Inatomi
- Work @Kaizen Platform
- Frontend Dev.
- ng-japan Organizer
- Angular Contributor
6/16 ng-japan 2018
data:image/s3,"s3://crabby-images/a654e/a654ecd0a9781da2ea8f5cd1bc7c5f813291bed0" alt=""
Agenda
1. Angular "on" WC
2. Angular "with" WC
3. Angular "for" WC
1. Angular "on" WC
-
Custom Elements
-
Shadow DOM
-
Template
-
HTML Imports
Web Components
Custom Elements
Angular Component
data:image/s3,"s3://crabby-images/f588a/f588a2eba5fdb3e2772a8ac8543570f2ab24c3c8" alt=""
data:image/s3,"s3://crabby-images/d3900/d3900a233ab66e2810cba54378bba2cc901a9a01" alt=""
data:image/s3,"s3://crabby-images/feb7a/feb7a674b68dcdf0b610059c44b380d0da0c6d63" alt=""
Component is like CE
-
Emulating Custom Elements
-
Custom Tag
-
as HTMLUnknownElement
-
-
Input: Custom Attributes
-
Output: Custom Events
-
Component Style Guide
-
SHOULD Use kebab-case selector
-
Follow CE specification
-
data:image/s3,"s3://crabby-images/0df9a/0df9ab29e4e29717fc4efac294bda695062986cc" alt=""
Shadow DOM
Component Styles
-
Components can have its own styles
-
Automatic CSS Scoping
-
-
CSS Encapsulation Strategy
- Emulated Shadow DOM
-
Native Shadow DOM Support
- DEMO
-
Emulated
-
Run everywhere (Angular supports IE9)
-
Robust / well-tested
-
A bit of performance overhead
-
-
Native
-
Require browser support
-
No overhead
-
Emulated vs Native
2. Angular "with" WC
- 100% Support!
- Same to native elements / components
- [propName]
- [attr.foo]
- (eventName)
Custom Elements Support
data:image/s3,"s3://crabby-images/88af0/88af031df16ac91323573abbe7fbc0080457042d" alt=""
CUSTOM_ELEMENTS_SCHEMA
data:image/s3,"s3://crabby-images/7eca0/7eca01f0ac759f9fd426001b48a47ccc28d75e60" alt=""
- Enable to use Unknown Tags
- DEMO
data:image/s3,"s3://crabby-images/ceaf2/ceaf2b37a38a0b300b82409211d74991268935ea" alt=""
data:image/s3,"s3://crabby-images/599a1/599a1a745124fb4061b48c95e8591a2682cef66d" alt=""
data:image/s3,"s3://crabby-images/78107/781077630b84190e478ae090ea4c533329280719" alt=""
Web Platform Collaboration
- Create: Polymer
- Publish: Web Components
- Use: Angular
data:image/s3,"s3://crabby-images/068c6/068c675873ae9216befe8282e789096de7831e86" alt=""
3. Angular "for" WC
-
Vanilla JS
-
extends HTMLElement
-
-
Polymer
-
extends PolymerElement
-
-
Vue
-
vue build --target wc
-
-
Angular
-
???
-
How to make CEs?
Angular Elements
Angular for www
-
Angular components everywhere
-
Demo (local)
data:image/s3,"s3://crabby-images/adf5f/adf5fd32beb10b8343150f6890849481750b9a81" alt=""
@angular/elements
data:image/s3,"s3://crabby-images/e86f5/e86f54db7f6cb4d18c17e06bf66d42124a83aa27" alt=""
data:image/s3,"s3://crabby-images/b5c7c/b5c7cddd6b5dd9c4cd631cb097eed534a5d2784f" alt=""
data:image/s3,"s3://crabby-images/f0ccf/f0ccfcc9090490ebc1c26c086a9783df44c3537b" alt=""
Conclusion
-
Angular is based on Web Components
-
Angular works with Web Components
-
Angular for making Web Components
Angular x Web Components
Angular ♥ Web Components!
Thanks!
data:image/s3,"s3://crabby-images/34d8c/34d8c500b99989d6bb132417b1d96917b42c995c" alt=""
Suguru Inatomi
AngularとWeb Components
By Suguru Inatomi
AngularとWeb Components
Web Components Cafe #2
- 6,483