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
noteのフロントエンドApp分割
Search
kozo yamagata
June 21, 2021
Programming
15
34k
noteのフロントエンドApp分割
noteでの大きくなりすぎたNuxt.jsのアプリケーションを分割する取り組みについて
kozo yamagata
June 21, 2021
Tweet
Share
More Decks by kozo yamagata
See All by kozo yamagata
コーヒー好きのエンジニアが自宅で焙煎を始めた話
kozo002
0
200
Other Decks in Programming
See All in Programming
Nuxt Server Components
wattanx
0
190
モックわからないマン卒業記 ~振る舞いを起点に見直した、フロントエンドテストにおけるモックの使いどころ~
tasukuwatanabe
3
430
AIと共にエンジニアとPMの “二刀流”を実現する
naruogram
0
100
Claude Code Skill入門
mayahoney
0
450
一度始めたらやめられない開発効率向上術 / Findy あなたのdotfilesを教えて!
k0kubun
3
2.1k
メッセージングを利用して時間的結合を分離しよう #phperkaigi
kajitack
3
500
Laravel Nightwatchの裏側 - Laravel公式Observabilityツールを支える設計と実装
avosalmon
1
270
テレメトリーシグナルが導くパフォーマンス最適化 / Performance Optimization Driven by Telemetry Signals
seike460
PRO
2
190
どんと来い、データベース信頼性エンジニアリング / Introduction to DBRE
nnaka2992
1
350
コードレビューをしない選択 #でぃーぷらすトウキョウ
kajitack
3
1.2k
20260320登壇資料
pharct
0
140
Xdebug と IDE による デバッグ実行の仕組みを見る / Exploring-How-Debugging-Works-with-Xdebug-and-an-IDE
shin1x1
0
260
Featured
See All Featured
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
122
21k
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
0
890
4 Signs Your Business is Dying
shpigford
187
22k
How to Talk to Developers About Accessibility
jct
2
160
Primal Persuasion: How to Engage the Brain for Learning That Lasts
tmiket
0
300
Public Speaking Without Barfing On Your Shoes - THAT 2023
reverentgeek
1
350
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
2.6k
ラッコキーワード サービス紹介資料
rakko
1
2.8M
Are puppies a ranking factor?
jonoalderson
1
3.2k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
1.1k
Introduction to Domain-Driven Design and Collaborative software design
baasie
1
690
End of SEO as We Know It (SMX Advanced Version)
ipullrank
3
4.1k
Transcript
None
noteのフロントエンドApp分割 2021-06-21(mon) 山形孝造
3 受託開発会社でエンジニア、フリーランスを経て 2020年3月にnote入社 ☕コーヒーを自宅で焙煎したり、農園に行ったりするくらいにスキ フロントエンド・エンジニア
山形孝造 (やまがた こうぞう) note.com/zochang twitter.com/kozo002 github.com/kozo002
note フロントエンド Appの課題 4
note inc. 初期:Ruby on Rails + AngularJS 5 Railsのassets上に実装されたSPA
なつかしのCoffeeScriptで書かれていた
note inc. - SSRできない - Headless browser で html生成してSEO対策 -
動作が遅い - WebpackではなくSprockets - CoffeeScriptで書かれている - モダンなJSに追いつけない => Nuxt.jsへ乗り換え 2018年夏頃から 6 問題点
note inc. - AngularJSはほんの一部残っている - 全て移行するのは時間の問題 - Nuxt移行チームは解散 - 僕が入社したのはこの後
=> AngularJS時代の問題は全て解決 Nuxt移行ほぼ完了 🎉 7
note inc. 新たな課題発生 😇
note inc. - AngularJS実装の機能+新機能がNuxt上に存在 - コード量が凄まじいことに - 😈ビルドが長い -
ローカルで開発着手できるまで時間がかかる - 途中で落ちる - デプロイが遅い - 影響範囲が広い - バタフライエフェクトのような障害が発生したことも - パフォーマンスが低下 - SEOにも悪影響 - パフォーマンス対策は別軸で進めている 9 Nuxt実装による現在の課題 💀
フロントエンド App分割 10 2021年2月から開始
note inc. - 新しい機能はNext.jsで実装中 - そのうち本体も分割していく - Nuxtを今すぐ捨てるわけではない - 🔥共通Componentsをどう解決するか
- 共通スタイル - Router問題 => これらの問題を解決していく 💪 フロントエンドApp分割 11
note inc. - Web Componentsを検討した - Stencil.jsを使ってみた - バンドルサイズがでかい -
SSRできない - Svelteを採用 🎉 - バンドルサイズが小さい - 試しにButtonを実装してみた - Stencil.js 36.8KB - Svelte 5.5KB(React adapterを含む) 共通Componentsをどう解決するか 12
note inc. - Svelteを採用 🎉 - TypeScript が気持ちよく書ける - Webpack
config を書けば Nuxt.js/Next.js 上で動く - SSR/Hydrationも簡単にできる => Github Packagesでライブラリ化 共通Componentsをどう解決するか 13
note inc. SvelteをReactで動かす例 14 svelteファイルがimportのために Webpack loaderを追加する 基本的にはtargetに要素を与えて
newするだけで動く ※実際にはもう少し対応が必要です ※これはSSRに対応していません
note inc. SvelteをVue(ver2系)で動かす例 15 svelteファイルがimportのために Webpack loaderを追加する 基本的にはtargetに要素を与えて
newするだけで動く ※実際にはもう少し対応が必要です ※これはSSRに対応していません
App分割をやって 見えてきたこと 16
note inc. - 新しいFramework/Libraryの知識 - 課題解決の引き出しになる - ビルドシステムを読み解く力 - 問題解決能力に直結
- 実装力 - コードを書くスピード、習熟度 - フットワーク - 分析力 - 成果物が求めていたものかを確かめられる 求められる技術と知識 17
note inc. - 個人的な想いから、アイデアを作る - 歯磨きしてる時、頭を洗っている時、散歩している時 - 仲間に相談すると同意を得られる - 単純にSlackでつぶやくだけ
- アイデア+αされてブラッシュアップされる - 上長に相談すると時間が得られる - 残業しなくて済む - お墨付きで改善を進められる - 小さく始めて少しずつ周りを巻き込む - すばやく試そう、つねにリーダーシップを、おおきな視点で考えよう まわりの協力が不可欠 18
19 noteの フロントエンドエンジニアを 募集中です 採用情報 https://open.talentio.com/1/c/note/requisitions/det ail/11493
None