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
Type Challengesに新しい問題を追加して Type ChallengesのMain...
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
301 Moved Permanently
May 24, 2025
Technology
1.2k
3
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Type Challengesに新しい問題を追加して Type ChallengesのMaintainerになった話
TSKaigi 2025の登壇資料です。
301 Moved Permanently
May 24, 2025
More Decks by 301 Moved Permanently
See All by 301 Moved Permanently
TypeScript 上達の道
ysknsid25
24
6.4k
Kotlinで学ぶ 代数的データ型
ysknsid25
5
1.7k
Java で学ぶ 代数的データ型
ysknsid25
4
2.1k
統計データで2024年の クラウド・インフラ動向を眺める
ysknsid25
2
1.4k
GAS × Discord bot × Gemini で作ったさいきょーの情報収集ツール
ysknsid25
1
2.3k
テストコード品質を高めるためにMutation Testingライブラリ・Strykerを実戦導入してみた話
ysknsid25
9
4.2k
そうだ、神戸へ行こう
ysknsid25
2
17k
テストコードの品質を客観的な数値で担保しよう〜Mutation Testのすすめ〜
ysknsid25
12
6.2k
「ばん・さく・つき・たー!」にならないためにSHIROBAKOから 学んだこと
ysknsid25
4
1.8k
Other Decks in Technology
See All in Technology
日本 Fintech 未来予測レポート 2027〜2028年(手動編集版)
8maki
0
230
Claude Code の Sandbox 機能を Anthropic Sandbox Runtime(srt) で試そう!/lets-play-anthropic-sandbox-runtime
tomoki10
1
450
「エンジニア進化論」2028年の開発完全自動化、エンジニアはどう進化するか
cyberagentdevelopers
PRO
3
2.1k
10倍の生産性を実現するAI駆動並列エージェントのすべて
kumaiu
4
1.2k
「嘘をつくテスト」の失敗例から学ぶ 良いテストコード #frontend_phpcon_do
asumikam
0
600
Rancherの紹介&Update情報(RancherJP Online Meetup #09)
yoshiyuki_kono
0
140
就職⽀援サービスにおけるキャリアアドバイザーのシフトスケジューリング
recruitengineers
PRO
1
110
MIERUNE JCT 発表資料「宇宙から伊能忠敬ごっこ」
syuchimu
0
200
社内 AI エージェント Synapse と セマンティックレイヤーの育て方
hiroakis
1
1.4k
LLMと共に進化するプロセスを目指して
ymatsuwitter
12
3.8k
中期計画、2回作ってみた ~業務委託と正社員、両方の視点から~
demaecan
1
600
ルールやカスタム機能、どう活かす?ハンズオンで体感するIBM Bobの出力コントロール
muehara
1
110
Featured
See All Featured
The Curious Case for Waylosing
cassininazir
1
380
Automating Front-end Workflow
addyosmani
1370
210k
Leveraging LLMs for student feedback in introductory data science courses - posit::conf(2025)
minecr
1
280
Distributed Sagas: A Protocol for Coordinating Microservices
caitiem20
333
22k
Scaling GitHub
holman
464
140k
sira's awesome portfolio website redesign presentation
elsirapls
0
270
Making Projects Easy
brettharned
120
6.7k
Side Projects
sachag
455
43k
Into the Great Unknown - MozCon
thekraken
41
2.6k
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
55k
Build your cross-platform service in a week with App Engine
jlugia
234
18k
The untapped power of vector embeddings
frankvandijk
2
1.7k
Transcript
Kanon #TSKaigi 2025 Type Challengesに新しい問題を追加して Type ChallengesのMaintainerになった話 ysknsid25 ysknsid25.bsky.social
2 Type Challengesとは
3 TypeScriptの型パズル集 Type Challengesとは
4 anyで定義された型を適切に定義する Type Challengesとは
このLTのゴール 5 帰ったらType Challenges解いてみよう と思ってもらうこと 初心者編
このLTのゴール 6 帰ったらType Challenges(他のOSSでも)に コントリビュートしてみよう と思ってもらうこと 中・上級者編
7 Type Challengesをやる理由 初心者編
こういう悩みを持ってる人にやってみてほしい 8 • ドキュメントとか参考書を読み込んだのに、全然型システムを使いこなせて る気がしない 😭 • この辺のキーワードに馴染みがない ◦ Inferring
Within Conditional Types ◦ Conditional Types ◦ Template Literal Types ◦ Indexed Access Types ◦ keyof Type Operator 初心者編
9 TypeScriptのいい教材はたくさんある 初心者編
10 公式ドキュメントも読む、読む、読む 初心者編
11 よっしゃTSの型システムを使いこなすぞ !!!!!!!! てんぷれーとりてらる?こんでぃしょなるたいぷ?なんぼのもんじゃい 初心者編
12 さーて いい感じに型を書き換えるOSSコントリビュートしていくか 初心者編
13 …
14 … …
15 … … …
16 ワイ「全然 書けねえじゃん」 ???「いや、申し訳ございません」 これの為だけにわざわざ十三行った
17 わかる と できる は違う いろんなところで言われてる話だけど 初心者編
18 Type Challengesってのがあるらしい やってみるか... 初心者編
19 全問解いたれ • 結論: 全部解く必要はないと思う ◦ hardからは型システムで計算とかし始める ◦ 「すごいけど実戦でいつ使うんそれ」な問題が大半 ◦
mediumまでを3周くらいすれば実戦でも勝手に手が動くようになる ◦ その頃にはOSSライブラリの型定義とかも難なく「読める、読めるぞぉ」となる(と思う) • 「Type Challengesは全問解く意味はない」という意見が本当か確かめるためにも解いた ◦ 自分もそれを言うためには全部解く必要があると思ったから 初心者編
20 全問解いたれ • 結論: 全部解く必要はないと思う ◦ hardからは型システムで計算とかし始める ◦ 「すごいけど実戦でいつ使うんそれ」な問題が大半 ◦
mediumまでを3周くらいすれば実戦でも勝手に手が動くようになる ◦ その頃にはOSSライブラリの型定義とかも難なく「読める、読めるぞぉ」となる(と思う) • 「Type Challengesは全問解く意味はない」という意見が本当か確かめるためにも解いた ◦ 自分もそれを言うためには全部解く必要があると思ったから 作者のAnthonyさん曰く 「mediumくらいまで解ければ普通にすごい」 って一昨日のスピーカーディナーで言ってた 初心者編
21 全通 + mediumまでを2周して解説本を書いた 初心者編
22 そんなある日 初心者編
23 これ問題作れるんじゃね? PR作成、っと… 初心者編
24 🎉
25 このへんで 量が質に転化 してきたこと を実感した 手がするする動いて他の OSSにもコントリビュートできるようになってきた 中・上級者編
26 追加した問題 中・上級者編
27 IsAlphabet 中・上級者編
28 IsAlphabet type IsAlphabet<S extends string> = any type cases
= [ Expect<Equal<IsAlphabet<'A'>, true>>, Expect<Equal<IsAlphabet<'z'>, true>>, Expect<Equal<IsAlphabet<'9'>, false>>, Expect<Equal<IsAlphabet<'!'>, false>>, Expect<Equal<IsAlphabet<'😂'>, false>>, Expect<Equal<IsAlphabet<''>, false>> ] あとで解きたい人はここから 中・上級者編
29 解答例
30 IsAlphabet 解答例 type IsAlphabet<S extends string> = Uppercase<S> extends
Lowercase<S> ? false : true; 受け取ったSが大文字にしても小文字にしても同じものはAlphabetでない • “A” と “a” • “!”, “😂”, “9”
31 後日談 中・上級者編
32 Type ChallengesのMaintainerになった 🎉 中・上級者編
33 Maintainerになった経緯 中・上級者編 • Type Challengesでレベルを上げたあとはUnJSにたくさんコントリビュートしてた • そこでAnthonyさんに何度かレビューしてもらう機会があった ◦ それこそ、ぶっ壊れてたlinterの設定修正とか
• その後blueskyで相互フォローになりちょこちょこ話すことがあった • 一昨日のスピーカーディナーで ”はじめまして”して、Type Challegesの話題になった • 自分が書いたZenn Bookを見てもらったところ、「メンテナーやってみる?」とお誘いをいただく というジョブズもびっくりな ”Connect the dots”確変イベントが発生した 当初このLTは問題追加したところで終わりだった
34 まとめ
35 まとめ • いい教材(インプット材料 )を読んで、 Type Challengesのmediumまでを3 周くらいする と学習効果が高そう ◦
型システム周りを手を止めずにコーディングできるようになってくる ◦ OSSのライブラリのコードも「読める、読めるぞぉ」になる ◦ 突然新しい問題を思いつくようになる • 量が質に転化する • Type Challengesに限らずOSSに貢献するといいことがある (かもしれない ) • 自分が会ってみたい人がいる場所があれば、是非会いに行こう
36 食戟のソーマ 13巻 63~64p 出会うことだ 出会うことでしか 料理人は前に進めない たった一人で皿に向き合っても それまでと変わらぬ自分が映るだけ 才波
城一郎
37 学び、繋がり、 ”型”を破ろう
Happy Hacking !! 水瀬いのり さんが推し の @ysknsid25 @ysknsid25.bsky.social Presented by
Kanon でした