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
Shouta
March 23, 2024
Programming
8
2k
フロントエンドパフォーマンス 入門
Shouta
March 23, 2024
Tweet
Share
Other Decks in Programming
See All in Programming
C-Shared Buildで突破するAI Agent バックテストの壁
po3rin
0
430
ゲームの物理 剛体編
fadis
0
390
リリース時」テストから「デイリー実行」へ!開発マネージャが取り組んだ、レガシー自動テストのモダン化戦略
goataka
0
160
Python札幌 LT資料
t3tra
7
1.1k
GoLab2025 Recap
kuro_kurorrr
0
790
AI前提で考えるiOSアプリのモダナイズ設計
yuukiw00w
0
210
Flutter On-device AI로 완성하는 오프라인 앱, 박제창 @DevFest INCHEON 2025
itsmedreamwalker
1
180
はじめてのカスタムエージェント【GitHub Copilot Agent Mode編】
satoshi256kbyte
0
140
PC-6001でPSG曲を鳴らすまでを全部NetBSD上の Makefile に押し込んでみた / osc2025hiroshima
tsutsui
0
200
フルサイクルエンジニアリングをAI Agentで全自動化したい 〜構想と現在地〜
kamina_zzz
0
340
Pythonではじめるオープンデータ分析〜書籍の紹介と書籍で紹介しきれなかった事例の紹介〜
welliving
3
750
脳の「省エネモード」をデバッグする ~System 1(直感)と System 2(論理)の切り替え~
panda728
PRO
0
130
Featured
See All Featured
Ecommerce SEO: The Keys for Success Now & Beyond - #SERPConf2024
aleyda
1
1.8k
SERP Conf. Vienna - Web Accessibility: Optimizing for Inclusivity and SEO
sarafernandez
1
1.3k
A Modern Web Designer's Workflow
chriscoyier
698
190k
End of SEO as We Know It (SMX Advanced Version)
ipullrank
2
3.8k
Docker and Python
trallard
47
3.7k
Facilitating Awesome Meetings
lara
57
6.7k
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2k
AI Search: Where Are We & What Can We Do About It?
aleyda
0
6.8k
The SEO identity crisis: Don't let AI make you average
varn
0
45
Documentation Writing (for coders)
carmenintech
77
5.2k
Large-scale JavaScript Application Architecture
addyosmani
515
110k
SEO for Brand Visibility & Recognition
aleyda
0
4.1k
Transcript
フロントエンドパフォーマンス 入門 内山 翔太
自己紹介 基本的に興味関心がパフォーマンスに全振りしています SES で働いています 普段は Java を書いており、フロントエンドは趣味です(?)
今日の内容 Core Web Vitals Web パフォーマンスにおいて確認すべき要素 すぐに取り組める改善
Web サイトのパフォーマンスの重要性 ユーザー体験の向上 ユーザー体験が悪いと離脱してしまう Amazon では表示速度が 0.1 秒遅くなると売上が 1 %減少すると言われている
( 後述する) Core Web Vitals は検索順位にも影響を与える 訪問者あたりの収益が 53.37% 、コンバージョン率が 33.13% 増加したケースもあ るらしい。 https://web.dev/case-studies/rakuten?hl=ja
Core Web Vitals とは Google が提唱するパフォーマンスの指標のことです。 Core Web Vitals は、ページの読み込みパフォーマンス、インタラクティブ性、視
覚的安定性に関する実際のユーザー エクスペリエンスを測定する一連の指標で す。 https://developers.google.com/search/docs/appearance/core-web-vitals?hl=ja Lighthouse や PageSpeed Insights で手軽に計測できます。
Core Web Vitals の指標を解説 First Contentful Paint (FCP) ページで一番最初に描画されるまでにかかった時間 Largest
Contentful Paint (LCP) 最も大きな要素が描画されるまでにかかった時間 Total Blocking Time (TBT) ページがユーザー入力に応答できない時間 最近だと、Hydration と呼ばれる処理にかかる時間が長いことで悪化しやすい 印象 Cumulative Layout Shift (CLS) レイアウトシフトがどのくらい起きているかの指標
Web パフォーマンスにおい て確認すべき要素 フロントエンドエンジニアが確認す るべきは フロントエンド ネットワークの帯域( ファイルサ イズなど) React
Server Components(RSC) の登場でバックエンドまで見る 必要も... ? https://twitter.com/takehora/statu s/1499185146779607045
この画像で何を伝えたかったのか? ファイルサイズは数多くある要素の内の一部である。 ファイルサイズの削減、圧縮はその一部のみに効く施策である minify は計算量を削減しないし、処理同士の依存関係も解消しない サイト全体のファイルサイズが小さい = 速いではない 逆に、サイトが遅い =
ファイルサイズが大きいでもない!!! 処理のコスト、順序を考えるのが大切
これらの知識をどう活かすか これらの知識がなんとなくでも身につくと、どの技術が何を解決するために生まれた のか。自分はどの技術を採用すればいいのか理解しやすくなります。 例えば RSC はサーバー側で React コンポーネントを実行し、ブラウザでの実行 コストを削減する技術です。 ブラウザ上での
JavaScript の実行コストが減ると、ユーザー入力を妨げる重たい 処理が減るので、TBT や Time to Interactive( 紹介しきれなかった...) が改善する。
おまけ 最新の HTML 、CSS を学ぼう! ライブラリを使わなくても dialog 要素でダイアログ, details 要素でアコーディオ
ンを簡単に作れる。 ライブラリを使用するよりバンドルサイズも小さくなる。 軽量なライブラリを選定しよう。 bundlephobia や Shakerphobia を使用するとバンドルサイズを測定できます。 https://bundlephobia.com/ 本当にそのライブラリ必要ですか?? 上 2 つとも関係しますが、最近の HTML,CSS,JavaScript は進化しています。 標準の技術で実現できないのか?自作できないのか? まずは検討してみよう!!
おわり 入門ということで、 パフォーマンスの指標 パフォーマンスはいろんな要素が絡んでいること を中心に話しました。 ご清聴ありがとうございました!