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.3k
実践!カスタムインストラクション&スラッシュコマンド
puku0x
2
3.2k
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
AIコーディングエージェントの活用で、コードは静かに肥大化した
yosukeshinoda
1
340
責任あるソフトウェアエンジニアリングの紹介4章・5章 / RSE_Ch4-5
ido_kara_deru
0
320
TypeScriptで実現する既存APIを活用したリモートMCPサーバー構築 / TSKaigi 2026
soarteclab
1
280
Geek Woman の育ち方 〜コミュニティとAIと〜
chicaco
0
410
類似画像検索モデルの開発ノウハウ
lycorptech_jp
PRO
3
790
イベントで大活躍する電子ペーパー名札 〜その3〜 / ビジュアルプログラミングIoTLT vol.23
you
PRO
0
130
【ハノーバーメッセ振り返りイベントat名古屋】データは集約からAI起点の収集に ~組織内・組織間でのデータ連携~
tanakaseiya
0
110
Kaggle未経験社員をメダリストに育てる「AIドラゴン桜」
lycorptech_jp
PRO
0
540
ソフトウェアサプライチェーン攻撃対策として今からサクッとできること
flatt_security
2
130
LLM時代のリファクタリング戦略_AIエージェントによる段階的・安全なTS移行方法
play_inc
0
180
A Harness for Behaviour: how to get AI to generate code that does what we intend, or "TDD in the age of AI"
xpmatteo
0
410
NFLコンペ2026 解法
lycorptech_jp
PRO
0
110
Featured
See All Featured
Typedesign – Prime Four
hannesfritz
42
3k
Done Done
chrislema
186
16k
AI Search: Where Are We & What Can We Do About It?
aleyda
0
7.5k
Designing Experiences People Love
moore
143
24k
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
55k
The Cult of Friendly URLs
andyhume
79
6.9k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
659
62k
Impact Scores and Hybrid Strategies: The future of link building
tamaranovitovic
0
280
Marketing to machines
jonoalderson
1
5.3k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
122
21k
Leo the Paperboy
mayatellez
7
1.8k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
360
30k
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