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.
→
Kanon
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の登壇資料です。
Kanon
May 24, 2025
More Decks by Kanon
See All by Kanon
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
2026 TECHFRESH 畢業分享會 - 開發日常大解密!從領域驅動到企業級上線
line_developers_tw
PRO
0
820
プロダクト開発から業務改善コンサルまで。事業全体へ「染み出す」ことで広がるエンジニアの可能性
ham0215
0
110
Claude Codeをどのように キャッチアップしているか
oikon48
9
5.4k
DevOps Agentで始めるAWS運用 〜フロンティアエージェントが変える運用の現場〜
nyankotaro
1
380
脆弱性対応、どこで線を引くか
rymiyamoto
1
370
AI駆動開発を通して感じた、 AI時代のデザイナーの役割変化
whisaiyo
0
260
日本 Fintech 未来予測レポート 2027〜2028年(手動編集版)
8maki
0
2k
[モダンアプリ勉強会]今更聞けないGit/GitHub入門
tsukuboshi
0
370
20260619 私の日常業務での生成 AI 活用
masaruogura
1
130
エンジニアリング戦略の作り方 / Crafting Engineering Strategy
iwashi86
20
6.6k
AIはどのように 組織のアジリティを変えるのか?
junki
0
310
Claude Code の Sandbox 機能を Anthropic Sandbox Runtime(srt) で試そう!/lets-play-anthropic-sandbox-runtime
tomoki10
1
540
Featured
See All Featured
The Cost Of JavaScript in 2023
addyosmani
55
10k
Building Flexible Design Systems
yeseniaperezcruz
330
40k
Bash Introduction
62gerente
615
220k
The agentic SEO stack - context over prompts
schlessera
0
810
Automating Front-end Workflow
addyosmani
1370
210k
Six Lessons from altMBA
skipperchong
29
4.3k
First, design no harm
axbom
PRO
2
1.2k
Building the Perfect Custom Keyboard
takai
2
790
Building a Scalable Design System with Sketch
lauravandoore
463
34k
A designer walks into a library…
pauljervisheath
211
24k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
9
1.4k
Stewardship and Sustainability of Urban and Community Forests
pwiseman
0
220
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 でした