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
tRPCの紹介
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Yohei Iino
June 06, 2023
Technology
280
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
tRPCの紹介
tRPCの紹介
Yohei Iino
June 06, 2023
More Decks by Yohei Iino
See All by Yohei Iino
1年半放置したExpo製アプリを最新化してみた
wheatandcat
0
100
作成中のFlutterアプリの中間発表
wheatandcat
0
83
最近読んだ技術書を簡単紹介
wheatandcat
0
110
ユニバーサルリンク/アプリリンクを使ってQRコードでゲストログインできるようにする
wheatandcat
0
380
Firebase App Checkを実装したので紹介
wheatandcat
0
310
PlanetScaleの無料プランがなくなるので、NeonとTiDBを試してみた
wheatandcat
0
410
Flutter HooksとRiverpodの解説
wheatandcat
0
580
T3 Stack(応用編: Next Auth & SSRの実装紹介)
wheatandcat
1
400
App Routerの紹介
wheatandcat
0
150
Other Decks in Technology
See All in Technology
AI 不只幫你寫 Code: 當專案從 300 暴增到 1500, 我們如何撐住 DevOps
appleboy
0
280
技術・能力を向上する原理原則 #きのこセッションa #きのこ2026
bash0c7
0
140
AIに障害切り分けを全部やってもらった。 。 。 。
estie
0
250
WebGIS AI Agentの紹介
_shimizu
0
580
螺旋型キャリアの生存戦略 / kinoko-conf2026
rakus_dev
1
1.2k
コミットの「なぜ」を読む
ota1022
0
120
AI時代のコスト管理を考えよう〜明日から使える実践AWSノウハウ~
yoshimi0227
0
930
データレイクの「見えない問題」を可視化する
sansantech
PRO
1
220
AIAU_UMEMOGU_ninomiya_slide
ninomiya_ii
0
270
いまさら聞けない「仕様駆動開発入門」 〜AI活用時代の開発プロセスを考える〜
findy_eventslides
2
230
5分でわかる Amazon Connect_20260608
hwangbyeonghun
0
130
Hatena Engineer Seminar 37 jj1uzh
jj1uzh
0
140
Featured
See All Featured
The #1 spot is gone: here's how to win anyway
tamaranovitovic
3
1.1k
Tell your own story through comics
letsgokoyo
1
980
Learning to Love Humans: Emotional Interface Design
aarron
275
41k
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2.3k
Ten Tips & Tricks for a 🌱 transition
stuffmc
0
140
The World Runs on Bad Software
bkeepers
PRO
72
12k
Navigating Algorithm Shifts & AI Overviews - #SMXNext
aleyda
1
1.3k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
35
3.5k
Navigating the Design Leadership Dip - Product Design Week Design Leaders+ Conference 2024
apolaine
1
360
Visual Storytelling: How to be a Superhuman Communicator
reverentgeek
2
570
Sam Torres - BigQuery for SEOs
techseoconnect
PRO
0
290
SEO in 2025: How to Prepare for the Future of Search
ipullrank
3
3.6k
Transcript
tRPC の紹介 Press Space for next page
自己紹介 📝 飯野陽平(wheatandcat ) 🏢 法人設立(合同会社UNICORN 代表社員) 💻 Work: シェアフル株式会社CTO
📚 Blog: https://www.wheatandcat.me/ 🛠 今までに作ったもの memoir ペペロミア MarkyLinky Atomic Design Check List
tRPC とは? スキーマやコード生成なしで型安全なAPI の連携が行えるPRC フレームワーク 比較対象としては、GraphQL やOpenAPI などの技術に該当 TypeScript に特化しており、非常にシンプルに実装できる
BFF として利用されることも多い
そもそもRPC とは? RPC ( Remote Procedure Call ) とは、ネットワークで繋がっている別のコンピュータのプログラムを実行 できるようにする技術
クライアント側からサーバー側への疎通を行う際に、具体的な通信手段やプロトコルを意識することな く、関数の呼び出しを行うことがでやり取りが行える仕組み Google が開発したRPC のプロトコルなので、gRPC という命名になっている tRPC のt はTypeScript を表している
学ぶモチベーション OpenAPI やGraphQL だとスキーマ定義が必須でコード以外の実装が入りファットになりがち またフロントエンド側を型安全にするためには、さらに別途でコード生成の対応が必要 気軽にかつ型安全を保ちながらAPI を実装したい なので、tRPC を使ってみた
サーバー側の実装 参考:quickstart import { createHTTPServer } from "@trpc/server/adapters/standalone"; import {
initTRPC } from "@trpc/server" const t = initTRPC.create(); const appRouter = t.router({ helloWorld: t.procedure.query(() => { return "Hello World"; }), }); export type AppRouter = typeof appRouter; const server = createHTTPServer({ router: appRouter, }); server.listen(8000);
クライアント側の実装(スクリプト) import { createTRPCProxyClient, httpBatchLink } from "@trpc/client"; import type
{ AppRouter } from "./server"; const trpc = createTRPCProxyClient<AppRouter>({ links: [ httpBatchLink({ url: "http://localhost:3000", }), ], }); trpc.helloWorld.query().then((res) => { // output "Hello World" console.log(res); });
クライアント側の実装(スクリプト) コードでは以下のように補完が表示される
クライアント側の実装(React) 公式でHooks が提供されているので使用して実装 https://trpc.io/docs/reactjs/setup
クライアント側の実装(React) ▪ containers/Trpc.tsx import { useState } from "react"; import
{ QueryClient, QueryClientProvider } from "@tanstack/react-query"; import { httpBatchLink } from "@trpc/client"; import { trpc } from "../utils/trpc"; type Props = { children: React.ReactNode; }; function Trpc(props: Props) { const [queryClient] = useState(() => new QueryClient()); const [trpcClient] = useState(() => trpc.createClient({ links: [ httpBatchLink({ url: "http://localhost:8080", }), ], }) ); return ( <trpc.Provider client={trpcClient} queryClient={queryClient}> <QueryClientProvider client={queryClient}> {props.children} </QueryClientProvider> </trpc.Provider> );
クライアント側の実装(React) ▪ Page.tsx import { trpc } from "./utils/trpc"; export
default function IndexPage() { const userQuery = trpc.helloWorld.useQuery(); return <div>{userQuery.data}</div>; }
デモ: React + tRPC + Prisma で実装 ▪ GitHub https://github.com/wheatandcat/tRPC-demo/tree/main/trpc-react-prisma
デモを見せながらコードを解説 Prisma でDB の定義を行う server/prisma/schema.prisma tRPC とPrisma の連携 server/src/router.ts React との連携 client/src/Page.tsx
補足: Deno + tRPC を試す ▪ GitHub https://github.com/wheatandcat/deno-trpc-demo モチベーション 何だかんだでTypeScript
をデプロイするのが面倒だったので、Deno で行けたら1 つで全て済むと思 って試してみた 結果 tRPC の実装はできるけど、Deno で実装したファイルをimport できるのはDeno のみなので、結果フ ロントエンドもDeno で実装する必要がある こうなってくると旨味が薄れるので、まだ実用段階ではなかったなという感想
補足: 手軽にtRPC を試すならCreate T3 App がおすすめ T3 Stack のdemo アプリを簡単に作成できる
フロントエンド界隈で新しく提唱されているT3 Stack について調べてみた 実行方法は以下を参照 Introduction • Create T3 App
まとめ コードジェネートして型安全をする方法に慣れきっていたが、tRPC はコードジェネートしなくても型安 全が実現できるので手軽感がかなりある TypeScript 周りのツールも大分充実してきて書きやすいので、tRPC を使っていくのも全然有り BFF 構成なら、GraphQL より筋が良さそう
ご清聴ありがとうございました 🎉