Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Web Componentsの現在地
Search
ponday
February 10, 2018
Technology
2
3.3k
Web Componentsの現在地
FUKUOKA Engineers Day 2018発表資料
ponday
February 10, 2018
Tweet
Share
More Decks by ponday
See All by ponday
関数型でGoFのデザインパターンやってみる
honda
1
1.6k
TypeScriptの型表現
honda
10
3.1k
Web Componentsの今
honda
1
470
これまでのReact、これからのReact
honda
0
330
Gatsbyお試し
honda
0
130
styled-components or emotion?
honda
0
710
Web ComponentsとAngular
honda
0
150
Atomic Design周りについての私見
honda
1
780
え、まだWeb Componentsを未来の技術だと思ってるの?
honda
2
880
Other Decks in Technology
See All in Technology
非情報系研究者へ送る Transformer入門
rishiyama
3
2.1k
元エンジニアPdM、IDEが恋しすぎてCursorに全業務を集約したら、スライド作成まで爆速になった話
doiko123
1
480
類似画像検索モデルの開発ノウハウ
lycorptech_jp
PRO
4
1k
オレ達はAWS管理をやりたいんじゃない!開発の生産性を爆アゲしたいんだ!!
wkm2
4
420
When an innocent-looking ListOffsets Call Took Down Our Kafka Cluster
lycorptech_jp
PRO
0
100
vLLM Community Meetup Tokyo #3 オープニングトーク
jpishikawa
0
220
プロジェクトマネジメントをチームに宿す -ゼロからはじめるチームプロジェクトマネジメントは活動1年未満のチームの教科書です- / 20260304 Shigeki Morizane
shift_evolve
PRO
1
140
AIエージェント時代に備える AWS Organizations とアカウント設計
kossykinto
2
390
男(監査)はつらいよ - Policy as CodeからAIエージェントへ
ken5scal
5
780
AIエージェント・エコノミーの幕開け 〜 オープンプロトコルが変えるビジネスの未来 〜
shukob
0
110
「ヒットする」+「近い」を同時にかなえるスマートサジェストの作り方.pdf
nakasho
0
150
クラウド時代における一時権限取得
krrrr38
1
170
Featured
See All Featured
Crafting Experiences
bethany
1
81
AI: The stuff that nobody shows you
jnunemaker
PRO
3
360
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.3k
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
2.4k
The SEO Collaboration Effect
kristinabergwall1
0
380
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
9
1.2k
Building an army of robots
kneath
306
46k
Raft: Consensus for Rubyists
vanstee
141
7.3k
The agentic SEO stack - context over prompts
schlessera
0
680
Let's Do A Bunch of Simple Stuff to Make Websites Faster
chriscoyier
508
140k
How Software Deployment tools have changed in the past 20 years
geshan
0
32k
The Power of CSS Pseudo Elements
geoffreycrofte
82
6.2k
Transcript
Web Componentsの現在地 FUKUOKA Engineers Day 2018 / Feb 10th, 2018
/ Yusuke, Honda
Profile Honda, Yusuke (@ponday) その辺にいるSIer フロントエンドの話ばかりしているけどフロントエンドエンジニアではない
Web Components?
Web Components HTML / CSS / JSで 再利用可能な部品を作る Web API
=
Web Componentsの構成 - Custom Elements - Shadow DOM - HTML
Template - HTML Imports
Web Componentsの構成 - Custom Elements - Shadow DOM - HTML
Template - HTML Imports
Custom Elements HTMLに独自の要素を 追加する仕組み =
Custom Elements
Custom Elements HTMLElementを継承して Custom Elementを定義
Custom Elements Shadow DOMを有効化 テンプレートを定義 ※ templateタグを利用する方法も
Custom Elements my-elementタグとして コンポーネントを登録
Web Componentsの構成 - Custom Elements - Shadow DOM - HTML
Template - HTML Imports
Shadow DOM 各コンポーネントが 独自のDOMツリーを持つ =
html 通常 head body div div h1 input button DOM
DOMツリーは単一 = 全てグローバル
html Shadow DOMが入ると... head body div my-element h1 input button
DOM Shadow DOMは他のDOMツリーから独立 → CSSやJSの影響範囲をカプセル化できる Shadow DOM
None
通常の要素はそのまま Shadow DOMには影響しない
Web Componentsの構成 - Custom Elements - Shadow DOM - HTML
Template - HTML Imports
HTML5で追加されたtemplate要素のこと
Web Componentsの構成 - Custom Elements - Shadow DOM - HTML
Template - HTML Imports
仕様の合意が取れず放棄されました
Web Componentsの概要はここまで
じゃあ、実際Web Componentsって使えるの?
実は既にあるサービスで使われてます
None
None
とはいえ
各ブラウザの対応状況 (2018/02/04時点) Shadow DOM Custom Elements HTML Template ◦ ◦
◦ Chrome - ◦ ◦ Firefox ◦ ◦ ◦ Safari - - ◦ Edge ◦ ◦ ◦ Android Chrome ◦ ◦ ◦ iOS Safari ※ 59~ ※ 10.3~ ※ 部分的サポートを含む ※ IEはすべての仕様に非対応
現状ではpolyfillの利用はほぼ必須
webcomponents.js - Web Components用のpolyfill - Firefox、EdgeだけでなくIE11にも対応 - CSSのカプセル化はデフォルトでは無効 - Shady
CSSというpolyfillを利用 - パフォーマンス上の問題でカプセル化はしていない - YoutubeもShady CSSを使っているらしく、CSSのカプセル化は使ってい ない
しかし
各ブラウザの対応状況 (2018/02/04時点) Shadow DOM Custom Elements HTML Template ◦ ◦
◦ Chrome - ◦ ◦ Firefox ◦ ◦ ◦ Safari - - ◦ Edge ◦ ◦ ◦ Android Chrome ◦ ◦ ◦ iOS Safari ※ 59~ ※ 10.3~ ※ 部分的サポートを含む ※ IEはすべての仕様に非対応 開発中 開発中 Shadow DOMは優先度高
全ブラウザの対応もそう遠くはない(はず)
JSフレームワークはどうなる?
Vue.js - vue-cli - Vue.js公式のコマンドラインツール - VueコンポーネントをWeb Componentsとしてビルドする機能が開発中(ら しい) -
vue-custom-element (非公式) - 既に使える - VueのコンポーネントをWeb Componentsとして動作させる - Shadow DOMはデフォルトでoff
Angular - @angular/elements - 公式チームが実験的なプロジェクトとして実装中 - 次期バージョン6でリリース(予定) - AngularアプリをまるごとWeb Components化する
- 内部でRouterなども動作する - Ionic - Angularベースのモバイルアプリ向けフレームワーク - 次期バージョンでWeb Componentsベースに移行する方針で開発中
Polymer - Web ComponentsベースのJavaScriptライブラリ - Vue.jsやAngularと異なり、Web Componentsが普及する ほど使いやすくなる(はず) - 現在バージョン3が開発中
- HTML importsからES Moduleベースに切り替え中
JSフレームワークの未来予想 - 形はどうあれ、JSフレームワークはなくならない - Web Componentsをラップ / 糖衣構文を提供 (Polymer型) -
内部的にWeb Componentsの仕様を活用 (AngularのScoped CSS型) - Web Componentsを最小のコンポーネントとして扱う (ReactのPure Function Component型) - 既存のフレームワークも相互運用性は強めてくる - 競合するものではなく、共存可能なもの。役割分担が進むはず。 - いずれもコンポーネント志向という考え方は共通している - FW → Web Componentsのパスは既に見えてきてる
着実にWeb Componentsの世界は近づいている
Polyfillなしで、 あらゆるブラウザでWeb Componentsが使える日も近い
各ブラウザの対応状況 (2018/02/04時点) Shadow DOM Custom Elements HTML Template ◦ ◦
◦ Chrome - ◦ ◦ Firefox ◦ ◦ ◦ Safari - - ◦ Edge ◦ ◦ ◦ Android Chrome ◦ ◦ ◦ iOS Safari ※ 59~ ※ 10.3~ ※ 部分的サポートを含む ※ IEはすべての仕様に非対応
※ IEはすべての仕様に非対応
そう、IEさえいなければね(泣)
Thank you !!