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
puku0x
January 12, 2026
Technology
2k
2
Share
ファインディにおけるフロントエンド技術選定の歴史
フロントエンドの技術選定〜ピクシブ×Findyの事例に学ぶ〜
https://findy.connpass.com/event/379759/
puku0x
January 12, 2026
More Decks by puku0x
See All by puku0x
新メンバーのために、シニアエンジニアが環境を作る時代
puku0x
0
1.4k
Agent Skills 入門
puku0x
0
1.8k
生成AIではじめるテスト駆動開発
puku0x
0
1.2k
実践!カスタムインストラクション&スラッシュコマンド
puku0x
2
3.1k
Nx × AI によるモノレポ活用 〜コードジェネレーター編〜
puku0x
0
1.6k
ファインディにおけるフロントエンド技術選定の歴史
puku0x
2
300
ファインディでのGitHub Actions活用事例
puku0x
9
3.8k
Findyの開発生産性向上への取り組み ~Findyフロントエンドの場合~
puku0x
0
480
Findyの開発生産性を上げるためにやったこと
puku0x
1
660
Other Decks in Technology
See All in Technology
自動テストだけで リリース判断できるチームへ - 鍵はテストの量ではなくリリース判断基準の再設計にあった / Redesigning Release Criteria for Lightweight Releases
ewa
2
1.8k
The 7 pitfalls of AI
ufried
0
150
AI活用時代の事業判断高度化を導くエンジニアリング基盤 / 20260424 Atsushi Funahashi
shift_evolve
PRO
2
110
Modernizing Your HCL Connections Experience: Visual Report to chain, Profile Enhancements, and AI Integration
wannesrams
0
240
Microsoft 365 / Microsoft 365 Copilot : 自分の状態を確認する「ラベル」について
taichinakamura
0
430
「SaaSの次の時代」に重要性を増すステークホルダーマネジメントの要諦 ~解像度を圧倒的に高めPdMの価値を最大化させる方法~
kakehashi
PRO
3
3.4k
MySQL 9.7がやってきた ~これまでのあらすじと基本情報~ @ 日本MySQLユーザ会会2026年04月 / mysql97-yattekita
sakaik
0
150
20260428_Product Management Summit_Loglass_JoeHirose
loglassjoe
4
6.1k
【技術書典20】OpenFOAM(自宅で深める流体解析)流れと熱移動(2)
kamakiri1225
0
350
ブラウザの投機的読み込みと投機ルールAPIを理解し、Webサービスのパフォーマンスを最適化する
shuta13
1
210
AIはハッカーを減らすのか、増やすのか?──現役ホワイトハッカーから見るAI時代のリアル【MEGU-Meet】
cscengineer
PRO
0
240
AgentCore Managed Harness を使ってみよう
yakumo
2
280
Featured
See All Featured
Optimising Largest Contentful Paint
csswizardry
37
3.7k
Stewardship and Sustainability of Urban and Community Forests
pwiseman
0
190
"I'm Feeling Lucky" - Building Great Search Experiences for Today's Users (#IAC19)
danielanewman
231
23k
Fashionably flexible responsive web design (full day workshop)
malarkey
408
66k
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2.2k
The Anti-SEO Checklist Checklist. Pubcon Cyber Week
ryanjones
0
130
Designing for Performance
lara
611
70k
Optimizing for Happiness
mojombo
378
71k
Applied NLP in the Age of Generative AI
inesmontani
PRO
4
2.2k
The World Runs on Bad Software
bkeepers
PRO
72
12k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.8k
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
47
8.1k
Transcript
ファインディにおける フロントエンド技術選定の歴史 1 2026/01/13 フロントエンドの技術選定〜ピクシブ×ファインディの事例に学ぶ〜 ファインディ株式会社 フロントエンド テックリード 新福 宜侑
@puku0x
2 今年で9歳! 転職サービスの「Findy」
3 Findyのフロントエンド • Next.js + TypeScript + GraphQL • Jest、Testing
Library、Playwright • Prettier、ESLint、Stylelint、Commitlint • Storybook、Style Dictionary、Figma • Nx(モノレポ管理ツール)、pnpm • GitHub Actions • GitHub Copilot、Claude Code
以前のフロントエンド構成 4
5 以前(〜2020年)のフロントエンド構成 • Railsモノリス上のReact ◦ React 16 ◦ バージョンの古いツール‧ライブラリ多数 ◦
クラスコンポーネント ◦ 型(Flow)はある、テストは無い ◦ スケールし⾟い設計、ディレクトリ構成、etc. .. • モノリスのデメリット ◦ 軽微な修正でも⻑時間のCI待ちが発⽣ → 開発スピード低下
6 1. 開発スピード
7 モノリス解体
8 解体後のフロントエンドはNext.jsを採⽤ https://nextjs.org/
9 Next.jsの採⽤理由 • 既存のReactの資産を活かしたい • 複雑な部分をフレームワークに任せて開発スピードを上げる ◦ SSRの仕組み ◦ ビルド設定
◦ パフォーマンス最適化
モノリス解体完了! (〜2021年5⽉) 10
11 GitHub上のアクティビティ数: 4倍 リリース回数: 9.1倍 PRクローズまでの速度: 35倍 Findyがモノリス環境をやめて得られたユーザへの爆速価値提供 https://note.com/ma3tk/n/na502374b6ad6 モノリス解体の成果
モノリス解体で フロントエンドが最⾼になっ... 12
...てない! 13
14 モノリス解体後のフロントエンドの課題 • バージョンの古いツール‧ライブラリ多数 • 型(Flow)はあるが、うまく動いていない • テストが無い → 持続的な開発が困難
15 2. 持続的な開発
16 開発基盤の刷新
17 持続的に開発できる仕組みを整える • 定期的なアップデートの⾃動化 • ⾃動テストの拡充 • 不要なパッケージの削除 ◦ styled-components
+ classnames → Emotionに統⼀ ◦ Redux関連 → @reduxjs/toolkit → に統⼀
18 開発基盤にNxを採⽤ https://nx.dev/
19 Nxの採⽤理由 • 持続的な開発基盤 ◦ ESLintやJestなどがすぐに使える ◦ nx migrate による⾃動更新
• 今後の⼤規模化に備える ◦ nx affected による変更検知 → CI⾼速化 ◦ リモートキャッシュの活⽤で更に⾼速化できる
20 Flow → TypeScript に移⾏ Flowの型注釈を削除 ↓ TypeScript(allowJs: true) ↓
TypeScript(strict: true)
21 TypeScriptの採⽤理由 • 型が欲しい • JavaScriptからの移⾏のしやすさ • エディタとの相性 • 情報の豊富さ
• デファクトスタンダード
開発基盤の刷新で フロントエンドが最⾼になっ... 22
...てない! 23
24 REST API → GraphQL • パフォーマンスの課題を解決したい ◦ 当時のREST APIはページに使うデータが全てレスポンスに含まれていた
• 型が欲しい ◦ データ構造が⼀定でない場合もあり、⼿動での型付けが困難だった 社内ツールに導⼊‧検証 ↓ プロダクトを⼀部GraphQL化 ↓ プロダクトを全GraphQL化 ↓ 他のプロダクトに展開 → GraphQLに移⾏
25 Emotion → CSS Modules • App Router(React Server Components)の登場
◦ 新しいコンポーネント設計の模索 ◦ ランタイム CSS-in-JS からの脱却が議論されるようになる • さまざまな⽅法を検討し、CSS Modulesを採⽤ ◦ チーム要件や将来的な他ライブラリへの移⾏も加味して ◦ 2026年1⽉時点で ほぼ移⾏完了 EmotionからCSS Modulesへの移⾏!React Server ComponentsのCSS対応 https://tech.findy.co.jp/entry/2024/09/09/090000
26 3. 常に繰り返す
27 現在のファインディのフロントエンド共通の技術スタック ※SSRの要件の有無により使い分けています ※
28 まとめ • 技術選定のポイント 1. 開発スピード 2. 持続的な開発 3. 常に繰り返す
• リスペクトを持つ →「当時はそれが正解だった」 • 新しく導⼊するもの →「⼩さくはじめる」
技術選定って⼤変😂 29
リスペクトを忘れずに😉 30
31 ツール選定といえば...
ツール選定のお供に 32 各種ツールの活⽤事例や、様々なサービスのインフラアーキテクチャなど実⽤的な情報を多数掲載 https://findy-tools.io/
We’re hiring! https://careers.findy.co.jp/ 33