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高速化のススメ
Search
Atsushi Nakatsugawa
PRO
May 30, 2019
Technology
0
780
Web高速化のススメ
ゆるWeb勉強会 with Monaca UG in Sapporoの発表資料です。
https://monacaug.connpass.com/event/130871/
Atsushi Nakatsugawa
PRO
May 30, 2019
Tweet
Share
More Decks by Atsushi Nakatsugawa
See All by Atsushi Nakatsugawa
AIで急増した生産「量」の荒波をCodeRabbitで乗りこなそう
moongift
PRO
0
45
Codexとも仲良く。CodeRabbit CLIの紹介
moongift
PRO
1
450
リレーションからマーケティングへ。継続するDevRelのために行うべきこと
moongift
PRO
0
8
開発スピードとスキル向上を両立するAIコードレビューの活かし方
moongift
PRO
0
72
個人開発にAIレビューを導入しよう
moongift
PRO
0
47
AIによるコードレビューで開発体験を向上させよう!
moongift
PRO
0
850
AIによるコードレビューで開発体験を向上させよう!
moongift
PRO
0
1.3k
開発スピードとスキル向上を両立するAIコードレビューの活かし方
moongift
PRO
0
71
Let's speed up personal development with AI code reviews
moongift
PRO
0
40
Other Decks in Technology
See All in Technology
DSPy入門
tomehirata
6
850
今から間に合う re:Invent 準備グッズと現地の地図、その他ラスベガスを周る際の Tips/reinvent-preparation-guide
emiki
1
230
データエンジニアとして生存するために 〜界隈を盛り上げる「お祭り」が必要な理由〜 / data_summit_findy_Session_1
sansan_randd
1
770
LLM APIを2年間本番運用して苦労した話
ivry_presentationmaterials
5
900
現場の壁を乗り越えて、 「計装注入」が拓く オブザーバビリティ / Beyond the Field Barriers: Instrumentation Injection and the Future of Observability
aoto
PRO
1
840
ソースを読む時の思考プロセスの例-MkDocs
sat
PRO
1
360
プロファイルとAIエージェントによる効率的なデバッグ / Effective debugging with profiler and AI assistant
ymotongpoo
1
740
re:Inventに行くまでにやっておきたいこと
nagisa53
0
950
SREのキャリアから経営に近づく - Enterprise Risk Managementを基に -
shonansurvivors
1
700
Kotlinで型安全にバイテンポラルデータを扱いたい! ReladomoラッパーをAIと実装してみた話
itohiro73
3
140
abema-trace-sampling-observability-cost-optimization
tetsuya28
0
440
制約下の医療LLM Observability 〜セキュアなデータ活用と専門家による改善サイクルの実現〜
kakehashi
PRO
1
100
Featured
See All Featured
It's Worth the Effort
3n
187
28k
Navigating Team Friction
lara
190
15k
Fashionably flexible responsive web design (full day workshop)
malarkey
407
66k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
127
54k
Unsuck your backbone
ammeep
671
58k
Code Review Best Practice
trishagee
72
19k
Designing for Performance
lara
610
69k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
116
20k
Embracing the Ebb and Flow
colly
88
4.9k
Testing 201, or: Great Expectations
jmmastey
46
7.7k
Rails Girls Zürich Keynote
gr2m
95
14k
How To Stay Up To Date on Web Technology
chriscoyier
791
250k
Transcript
PAGE DAY 2019/02/14 # MOONGIFT / 50 Web高速化のススメ 1
PAGE # MOONGIFT / 50 DAY 2019/02/14 自己紹介 2 @goofmint
fb.me/goofmint 中津川 篤司 株式会社MOONGIFT代表取締役 エバンジェリスト コミュニティ 主催 https://www.moongift.jp
PAGE # MOONGIFT / 50 DAY 2019/02/14 今日お話しすること •フロントエンドでユーザ体験を向上させる •格好良さだけでなく実益につながる改善
3
PAGE # MOONGIFT / 50 DAY 2019/02/14 今日お話しないこと •Monacaのこと •サーバサイドの改善(Monacaはフロント向けなので…)
•実装 4
PAGE # MOONGIFT / 50 DAY 2019/02/14 よく使うWebサービス 5
PAGE # MOONGIFT / 50 DAY 2019/02/14 遅い = •2016年01月 読み込みに3秒かかると20%が離脱
•2018年11月 読み込みに3秒かかると53%が離脱 6
PAGE # MOONGIFT / 50 DAY 2019/02/14 遅い = •ECサイトで1秒遅いとコンバージョン率△7%
•Amazonでは0.1秒遅いと売上△1% 7
PAGE # MOONGIFT / 50 DAY 2019/02/14 旅行先にて Gwifiは1日500MBまで 切れると128kbps制限
追加購入したい サイトめっちゃ遅い… JavaScript動かない jQueryの読み込みでエラー出てる 8
PAGE # MOONGIFT / 50 DAY 2019/02/14
PAGE # MOONGIFT / 50 DAY 2019/02/14 高速化' 10
PAGE # MOONGIFT / 50 DAY 2019/02/14 高速化? 11 *
サーバ増強! ネットワーク回線強化! DOM改善 ネットワーク改善 プログラム改善
PAGE # MOONGIFT / 50 DAY 2019/02/14 Webフロントエンドのボトルネック •レンダリングが遅い、重たい •ネットワークが遅い
•JavaScript自体が遅い 12
PAGE # MOONGIFT / 50 DAY 2019/02/14 DOM改善 13
PAGE # MOONGIFT / 50 DAY 2019/02/14 仮想DOMを使いましょう •React/Vue.js/Riotなど •DOMを更新すべきかどうかはフレームワー
クに任せる •UI情報をJavaScriptにあらかじめ持たせる ことで、データ通信量を大幅に減らせる 14
PAGE # MOONGIFT / 50 DAY 2019/02/14 DOMの幅/高さを指定する •画像の高さがずれた時のDOM再計算が重い •テキストも可変にせず、溢れた時の処理を入れる
•iframeを使うと再計算処理が走らないので高速化する ↑実際やると結構地獄なので注意 https://vimeo.com/55486684 15
PAGE # MOONGIFT / 50 DAY 2019/02/14 UI/UX •アニメーションはCSS3でGPUを使う でも実装するのは大変
•ライブラリ、フレームワークを採用する •Onsen UI/ionic/Framework7など モバイル向けはデスクトップブラウザをサポートしていない ことがあるので注意 16
PAGE # MOONGIFT / 50 DAY 2019/02/14 ϒϥβ ϑϨʔϜϫʔΫ 0OTFO6*
*POJD 'SBNFXPSL
PAGE # MOONGIFT / 50 DAY 2019/02/14 ネットワーク改善 18
PAGE # MOONGIFT / 50 DAY 2019/02/14 CACHE APIを使おう! •JavaScriptから操作できるローカルプロキシ
•任意のURL、コンテンツをキャッシュ可能 19
PAGE # MOONGIFT / 12 DAY 2019/05/15 CACHE API •
Service Worker内で動作するキャッシュシステム • URLをキー、レスポンスをバリューにしたKVS • 有効期限などがないのでWorkboxと組み合わせると吉 20 リクエスト リクエスト Service Worker Webブラウザ レスポンス レスポンス サーバ キャッシュなし
PAGE # MOONGIFT / 12 DAY 2019/05/15 CACHE API •
Service Worker内で動作するキャッシュシステム • URLをキー、レスポンスをバリューにしたKVS • 有効期限などがないのでWorkboxと組み合わせると吉 21 リクエスト Service Worker Webブラウザ レスポンス サーバ キャッシュあり
PAGE # MOONGIFT / 12 DAY 2019/05/15 キャッシュパターン 22 ΦϯϥΠϯ
ΦϑϥΠϯ උߟ Ωϟογϡ ͋Γ ͳ͠ ͋Γ ͳ͠ ΩϟογϡϑΝʔετ Ωϟογϡ ωοτϫʔΫ Ωϟογϡ Τϥʔ جຊ ωοτϫʔΫϑΝʔετ ωοτϫʔΫ ωοτϫʔΫ Ωϟογϡ Τϥʔ ։ൃ࣌ʹ͓קΊ ΩϟογϡΦϯϦʔ Ωϟογϡ ωοτϫʔΫ Ωϟογϡ Τϥʔ ωοτϫʔΫΦϯϦʔ ωοτϫʔΫ ωοτϫʔΫ ωοτϫʔΫ Τϥʔ ։ൃ࣌ʹ͓קΊ ฏߦ ߋ৽ Ωϟογϡ ωοτϫʔΫ Ωϟογϡ Τϥʔ ΦϯϥΠϯͳΒΩϟογϡߋ৽ via Workbox
PAGE # MOONGIFT / 50 DAY 2019/02/14 メリット •ネットワークアクセスを大幅に減らせます •オフラインでもWebアプリケーションが使えます
23
PAGE # MOONGIFT / 50 DAY 2019/02/14 注意点 •キャッシュを自動更新する仕組みはありません •削除、更新する仕組みを作っておかないと大変なこと
になります •開発中はネットワークファーストで開発しましょう 24
PAGE # MOONGIFT / 50 DAY 2019/02/14 JavaScriptの速度改善 25
PAGE # MOONGIFT / 50 DAY 2019/02/14 WebAssemblyを使おう! •Webブラウザ上で動くバイナリフォーマット •超高速!
26
PAGE # MOONGIFT / 50 DAY 2019/02/14 速度比較(フィボナッチ) 27 JAVASCRIPT
WASM 20 2 1 30 69 4 40 6,733 423 42 17,356 1,061 44 46,195 2,839
PAGE # MOONGIFT / 50 DAY 2019/02/14 注意点 •WebAssemblyはプログラミング言語ではありません •WebAssemblyはDOMが扱えません
•WebAssemblyはネットワークが扱えません 28
PAGE # MOONGIFT / 50 DAY 2019/02/14 対応言語 •C/C++ •Rust
•C# •Java 29 •Go •AssemblyScript •Kotlin/Native •その他LLVM対応言語
PAGE # MOONGIFT / 50 DAY 2019/02/14 DOM/ネットワーク利用 30 1.
処理を依頼 2. 実行結果を返却
PAGE # MOONGIFT / 50 DAY 2019/02/14 DOM/ネットワークが使える言語 •Rust web-sysというcrate(ライブラリ)で実現
•Go syscall/jsというライブラリ 31
PAGE # MOONGIFT / 50 DAY 2019/02/14 Canvas/WebGLは使えます •メモリを直接書き換えるので複雑 •ゲーム、グラフィック描画には最適
32
PAGE # MOONGIFT / 50 DAY 2019/02/14 まとめ •DOM描画が遅い →
仮想DOMを使おう •ネットワークが遅い → CACHE APIを使おう •JavaScriptが遅い… → WebAssemblyを使おう 33
PAGE # MOONGIFT / 50 DAY 2019/02/14 + Thanks! @goofmint
fb.me/goofmint ご感想お待ちします!