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
Next.jsでClean ArchitectureとDDD
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
HYUNSEUNG
November 24, 2021
Programming
4.2k
4
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Next.jsでClean ArchitectureとDDD
HYUNSEUNG
November 24, 2021
More Decks by HYUNSEUNG
See All by HYUNSEUNG
新規プロダクト立ち上げとフロントエンド設計
dordieux
2
380
Other Decks in Programming
See All in Programming
Claspは野良GASの夢をみるか
takter00
0
190
Hunting Vulnerabilities in Symfony with LLMs
vinceamstoutz
0
540
Go1.27で導入されるジェネリクスメソッドでできること
mackee
0
120
エンジニアと一緒にテストコードの設計と実装を改善した話
mototakatsu
0
180
PHPで使える日時の表現と、その知り方 #frontend_phpcon_do
o0h
PRO
0
240
Mujeres en SEO Summit 2026 - Greatest Disaster Hits en Web Performance
guaca
0
180
エージェンティックRAGにAWSで入門しよう!
har1101
8
1.6k
Snowflake Summitでの新機能 CoCo / CoWork / snowflake-summit-2026-overall-what-new-coco
tatsuhiro
1
140
3Dシーンの圧縮
fadis
1
770
タクシーアプリ『GO』の バックエンド開発のおける AI利活用と若者のすべて
pyama86
3
2k
コンテキストの使い捨てをやめる — ビジネスルール駆動開発と miko —
ioki
0
200
技術記事、 専門家としてのプログラマ、 言語化
mizchi
13
6k
Featured
See All Featured
Lightning Talk: Beautiful Slides for Beginners
inesmontani
PRO
2
580
We Have a Design System, Now What?
morganepeng
55
8.2k
Crafting Experiences
bethany
1
180
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
2
1.5k
AI: The stuff that nobody shows you
jnunemaker
PRO
8
710
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
659
62k
AI Search: Where Are We & What Can We Do About It?
aleyda
0
7.6k
Conquering PDFs: document understanding beyond plain text
inesmontani
PRO
4
2.8k
[SF Ruby Conf 2025] Rails X
palkan
2
1.1k
More Than Pixels: Becoming A User Experience Designer
marktimemedia
3
440
Information Architects: The Missing Link in Design Systems
soysaucechin
0
970
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.4k
Transcript
1 Next.jsで Clean ArchitectureとDDD Hyunseung Park / 朴賢勝 Uzabase Inc,
Japan 2021.11.24 v12リリースを踏まえ、Next.jsの採用を考える 1
2 自己紹介 NewsPicks Expertとは - Next.jsを採用した理由 - Clean ArchitectureとDDDを採用した理由 実践
まとめ 01 02 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 2 アジェンダ 04 03
3 @dordieux dordieux • 朴 賢勝(Park Hyunseung) • 株式会社ユーザベース 2020/11/01
~ ◦ 2019年新卒から中途入社 ◦ SPEEDA, NewsPicks Expertなど 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 3 自己紹介
4 NewsPicks Expertとは 4
5 5 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 5 エキスパートプラットフォーム「NewsPicks Expert」 “
自分が持っている知識を社会のために役立てたい ” “ これまで培ってきた知見を異業種で生かしてみたい ” “ 社外の活動を通じて、知的な刺激を得たい ” エキスパートに登録いただく方々の想いはそれぞれですが、 共通していることは「専門性を生かし、貢献したい・活躍したい」という想い。 最先端ビジネス領域の第一人者や、その道30年の経験者など、 様々な業界・分野で実務経験を積んだ数多くの方々に、 「エキスパート」として登録いただいています。 私たちは「Expert First」を念頭に、 エキスパートとして登録いただく個人の方を第一に考え、 専門性を持った個人の方が活躍する機会を作り続けてまいります。 個人一人ひとりが活躍する機会を増やし、知見の流通を促すことで、 世界中の問題解決やイノベーションを加速させ、 エキスパートの皆様と一緒により良い世界をつくっていきたいと考えています。 MESSAGE
6 NewsPicks Expert 案件例(専門コメント FLASH Opinion:フラッシュオピニオン) クライアントの質問に対し、専門的な知見をお持ちであると思われる方に、メールで質問が届きます。 24時間以内に、200〜800文字で、ご回答をお願いします。 FLASH Opinionとは、クライアントの質問に対し、24時間以内にご回答いただくQ&A形式の案件です。 (FLASH
Opinionに回答いただいたエキスパートに「インタビューもしたい」というケースも数多くございます) クライアント SPEEDAで 質問投稿 エキスパート 24時間以内に 200字〜800字で 5名以上が回答 SPEEDAで 回答確認 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 6
7 7 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 7 NewsPicks Expert (https://newspicks.expert/)
https://newspicks.expert
8 8 Next.jsを 採用した理由 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 8
9 Next.jsを採用した理由 9 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 9 - Reactベース
- 素早く始められる - API Routes
10 10 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 10 マイクロフロントエンド・マイクロサービス 各プロジェクトチームで開発をしている しかしSPEEDAにReactはなかった
11 素早く始められる 11 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 11 typescript・Routing・SSR/SSG・ Webpack/babel
・Fast Refresh・ Image Optimization ・・・
12 API Routes 12 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 12 マイクロサービスアーキテクチャ
13 API Routes 13 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 13 マイクロサービスアーキテクチャ
BFFとして使う
14 14 フロントエンドで Clean Architectureと DDDを採用した理由 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える
/ 14
15 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 15 チーム構成 - チームは3~5人で構成されています -
定期的にチームメンバーは入れ替えます - 勤務時間、技術はチームによって異なります イヌチーム ネコチーム クマチーム
16 16 Clean ArchitectureとDDDを 全社的にやってる 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 16
17 17 Clean ArchitectureとDDDを 全社的にやってる 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 17
E2E・Unit Test
18 18 Clean ArchitectureとDDDを 全社的にやってる 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 18
E2E・Unit Test チームを移動しても すぐに馴染みやすい
19 Clean ArchitectureとDDD 19 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 19 一定のビジネスロジックは存在する
Componentとロジックを分離する
20 実践 20
21 21 ※Clean Architectureと DDD自体の説明は省略します 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 21
22 22 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 22 Dependency Injection フロントエンドでも同じく
依存性逆転が必要
23 23 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 23 Dependency Injection ビジネスロジックをしっかり
テストしたい ロジックを分離して外部要素と 切り離してテストする
24 24 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 24 Dependency Injection TypeScriptのDI
Containerのライブラリも充実してる - Inversify - TSyringe - Typed Inject - TypeDI - 自作 ・・・
25 25 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 25 @injectable() export class
UserUseCase { constructor(@inject("UserPort") readonly userPort: UserPort) {} async getSelf(): Promise<User> { return await this.userPort.find(); } } // DIコンテナーに追加 container.register("UserPort", { useClass: UserGateway });
26 26 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 26 フロントエンドだけでなく、 プロダクト全般
27 27 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 27 フロントエンドだけでなく、 プロダクト全般 フロントエンドに合わせて
同心円も考え直す必要がある
28 28 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 28 domain Use Case
Gateways Controllers API View Storage
29 29 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 29 domain Use Case
Gateways Controllers API view Storage View Controller UseCase Port state
30 30 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 30 domain Use Case
Gateways Controllers API view Storage View Controller UseCase Port state
31 31 Reactのstateと Clean Architectureのドメインを 紐付ける 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える
/ 31
32 32 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 32 export interface ExpertState
{ expertId: number; mailAddress: string; name: string; } export class Expert { constructor( readonly expertId: ExpertId, readonly mailAddress: MailAddress, readonly name: Name, ) {} } state domain
33 33 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 33 async function fetchMyPage()
{ return await container.resolve(MyPageController).get(); } const MyPage: NextPage = () => { const [profile, setProfile] = useState<Profile>({}); useEffect(() => { const run = async () => { const expert = await fetchMyPage(); setProfile({expert.id, expert.name ・・・}); }, []} }
34 34 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 34 @injectable() export class
MyPageController { constructor(readonly expertUseCase: ExpertUseCase) {} async get(): Promise<ExpertState> { const me = await this.expertUseCase.getSelf(); return { expertId: me.expertId.value, name: me.name.value ... } } }
35 35 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 35 export interface ExpertState
{ expertId: number; mailAddress: string; name: string; } export class Expert { constructor( readonly expertId: ExpertId, readonly mailAddress: MailAddress, readonly name: Name, ) {} } state domain
36 36 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 36 domain Use Case
Gateways Controllers API view Storage View Controller UseCase Port state
37 37 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 37 domain Use Case
Gateways Controllers API view Storage View Controller UseCase Port Presenter state
38 38 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 38 domain Use Case
Gateways Controllers API view Storage View Controller UseCase Port Presenter state
39 39 ReactのComponentで DI Container・Clean Architecture など意識したくない 【 Uzabase×forkwell 】v12リリースを踏まえ、
Next.jsの採用を考える / 39
40 40 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 40 async function fetchMyPage()
{ return await container.resolve(MyPageController).get(); } const MyPage: NextPage = () => { const [profile, setProfile] = useState<Profile>({}); useEffect(() => { const run = async () => { const expert = await fetchMyPage(); setProfile(expert); } }
41 41 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 41 const MyPage: NextPage
= () => { const profile = useProfile(); return ( <> ・・・ </> ) } function useProfile() { const expert = await container.resolve(MyPageController).get(); return {expert.id, expert.name ・・・}; }
42 42 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 42 domain Use Case
Gateways Controllers API view Storage View Controller UseCase Port Presenter state
43 まとめ 43
44 44 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 44 よかった点 - Next.jsでClean
Architecture・DDDの構成で リリースできた - ReduxやRecoilなど使わずにstateの管理ができた - Componentでビジネスロジックを持たなくなって 綺麗になった
45 45 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 45 伸び代 - Next.jsのfeatureを上手く使えてないかも
- SSR/SSG・細々な最適化 - custom hooksやcontextなどできてなかった
46 46 【 Uzabase×forkwell 】v12リリースを踏まえ、 Next.jsの採用を考える / 46 https://hatenanews.com/articles/20 21/05/26/103000 https://hatenanews.com/articles/20
21/06/29/103000 積極採用中です!