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
ブラウザレンダリングについて(簡易版)
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
kab0718
November 29, 2023
0
60
ブラウザレンダリングについて(簡易版)
kab0718
November 29, 2023
Tweet
Share
More Decks by kab0718
See All by kab0718
visxに触ってみた話
kab0718
0
230
アルゴリズムと計算量
kab0718
0
45
お嬢様言葉
kab0718
0
130
アイドルとコミュニケーション
kab0718
0
27
コーディングで意識してること
kab0718
0
49
趣味とぷよぐらみんぐ
kab0718
0
220
SDLアプリコンテスト2019プレゼン資料
kab0718
0
56
近況報告
kab0718
0
1.3k
アイドル×アイドル
kab0718
0
150
Featured
See All Featured
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
54k
The B2B funnel & how to create a winning content strategy
katarinadahlin
PRO
1
280
The innovator’s Mindset - Leading Through an Era of Exponential Change - McGill University 2025
jdejongh
PRO
1
93
Lessons Learnt from Crawling 1000+ Websites
charlesmeaden
PRO
1
1.1k
Google's AI Overviews - The New Search
badams
0
910
実際に使うSQLの書き方 徹底解説 / pgcon21j-tutorial
soudai
PRO
196
71k
ラッコキーワード サービス紹介資料
rakko
1
2.3M
Building an army of robots
kneath
306
46k
Become a Pro
speakerdeck
PRO
31
5.8k
Jess Joyce - The Pitfalls of Following Frameworks
techseoconnect
PRO
1
67
Fashionably flexible responsive web design (full day workshop)
malarkey
408
66k
世界の人気アプリ100個を分析して見えたペイウォール設計の心得
akihiro_kokubo
PRO
66
37k
Transcript
ブラウザレンダリングについて
概要 • ブラウザがページ表示するまでの流れ • 知ることのメリット ◦ パフォーマンス改善の原因特定 初期描画だけでなく操作に対しての応答速度も含む ◦
web系やるとき知っておけば便利 • ブラウザがやってくれてることなので知らなくても ものは作れる
工程 Download Parse Scripting Calculate Style Layout Paint Rasterize Paint
Composite Layers Loading Rendering Painting Frame
Download Parse Scripting Calculate Style Layout Paint Rasterize Paint Composite
Layers Loading Frame Rendering Painting
Loading • Download ◦ htmlやcss、JavaScriptファイル、画像などの リソースをサーバーからダウンロードする • Parse ◦
html/cssをパース(構文解析)してレンダリング用の データ構造に変換 html → DOMツリー css → CSSOMツリー
Download Parse Scripting Calculate Style Layout Paint Rasterize Paint Composite
Layers Loading Frame Painting Rendering
Scripting • JavaScriptファイルの実行 • JavaScriptのコードを解析してコンパイルすることで 実行可能な形式に変換 • 解析も以下の二段階に分かれて実施している ◦
字句解析 ソースコードをトークンと呼ばれる単位に分割 ◦ 構文解析 トークンの配列から抽象構文木を作成
Download Parse Scripting Calculate Style Layout Paint Rasterize Paint Composite
Layers Loading Frame Painting Rendering
Rendering • Calculate Style ◦ DOMツリー内のすべての要素に対してどのcssプロパティが 当たるか計算 ◦ cssルールのcssセレクタがマッチするか総当たりで実施
• Layout ◦ レイアウト情報の計算とレイアウトを実施 ◦ レイアウト情報とは →要素の大きさ/margin/padding/位置/z軸の位置
Download Parse Scripting Calculate Style Layout Paint Rasterize Paint Composite
Layers Loading Frame Painting Rendering
Painting • Paint ◦ 内部の2Dグラフィックエンジン向けの命令を生成 • Rasterize ◦ 生成された命名を基にレイヤーと呼ばれる単位で
ピクセルへと描画 ◦ レイヤーはz軸の上下関係を持つ • Composite Layers ◦ レイヤーを合成してレンダリング結果を生成
最後に • 大分端折った内容になった • 右の本でこの辺もっと詳しく書いてるらしい →今買ったので未読 • パフォーマンス系の問題に当たった時に 軽く思い出してほしい
• 目に見える部分だけでなく 低レイヤーの理解も大事