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
TypeScriptに興味を持って欲しいスライド
Search
koz
December 24, 2020
Technology
0
270
TypeScriptに興味を持って欲しいスライド
https://easy2.connpass.com/event/197872/
TypeScriptはいいぞっていう気持ちを伝えるための資料。
元々は社内向けだったものを、社外向けにリメイクした。
koz
December 24, 2020
Tweet
Share
More Decks by koz
See All by koz
3分でわかる WebRTCのP2P通信
koz
0
81
Angularの雰囲気を伝えたい
koz
0
61
Other Decks in Technology
See All in Technology
配列に見る bash と zsh の違い
kazzpapa3
3
170
広告の効果検証を題材にした因果推論の精度検証について
zozotech
PRO
0
210
データの整合性を保ちたいだけなんだ
shoheimitani
8
3.2k
SREチームをどう作り、どう育てるか ― Findy横断SREのマネジメント
rvirus0817
0
340
Embedded SREの終わりを設計する 「なんとなく」から計画的な自立支援へ
sansantech
PRO
3
2.6k
私たち準委任PdEは2つのプロダクトに挑戦する ~ソフトウェア、開発支援という”二重”のプロダクトエンジニアリングの実践~ / 20260212 Naoki Takahashi
shift_evolve
PRO
2
180
OWASP Top 10:2025 リリースと 少しの日本語化にまつわる裏話
okdt
PRO
3
840
日本の85%が使う公共SaaSは、どう育ったのか
taketakekaho
1
240
学生・新卒・ジュニアから目指すSRE
hiroyaonoe
2
740
今こそ学びたいKubernetesネットワーク ~CNIが繋ぐNWとプラットフォームの「フラッと」な対話
logica0419
4
330
2026年、サーバーレスの現在地 -「制約と戦う技術」から「当たり前の実行基盤」へ- /serverless2026
slsops
2
260
ECS障害を例に学ぶ、インシデント対応に備えたAIエージェントの育て方 / How to develop AI agents for incident response with ECS outage
iselegant
1
120
Featured
See All Featured
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.3k
Statistics for Hackers
jakevdp
799
230k
Facilitating Awesome Meetings
lara
57
6.8k
Exploring anti-patterns in Rails
aemeredith
2
250
Design in an AI World
tapps
0
150
Speed Design
sergeychernyshev
33
1.5k
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
21
1.4k
Build your cross-platform service in a week with App Engine
jlugia
234
18k
Documentation Writing (for coders)
carmenintech
77
5.3k
Docker and Python
trallard
47
3.7k
The State of eCommerce SEO: How to Win in Today's Products SERPs - #SEOweek
aleyda
2
9.6k
Bioeconomy Workshop: Dr. Julius Ecuru, Opportunities for a Bioeconomy in West Africa
akademiya2063
PRO
1
55
Transcript
TypeScriptはいいぞ (TypeScriptはいいぞ)
https://www.itmedia.co.jp/news/articles/2012/07/news146.html
こんな人たちに届いて欲しい JavaScriptを知っているけど、TypeScriptは良くわかってない TypeScriptを聞いたことある人 サーバーサイドメインでフロントあんまり興味ない人
自己紹介
koz (こじ/こず) @kozzzzz4 TOPGATE - 普段はフロント側 - Angular頑張ってます - サクナヒメ(?)やってます
None
こんな経験ありませんか?
Uncaught ReferenceError: hoge is not defined
Uncaught TypeError: Cannot read property 'fuga' of undefined
Uncaught ReferenceError: hoge is not defined
TypeScriptって何?
JavaScript 型
完全に理解した! やったね!
TypeScriptはあなたを救います
救われる3つの内容 • 型安全性 (バグが減らせる) • 開発効率が上がる • 開発のアプローチが変わる
型安全性 型安全性とは、型検査によって不正なプログラムが混入するのを防ぐこと。 つまり、「型安全性 ≒ バグが減る」。
開発効率が上がる IDEによるコード補完が効きます。 これもTypeScriptを使用することによる恩恵です。 つまらないタイプミスとはおさらばです。
アプローチが変わる 型を考える→ロジックを組む。 JavaScriptを使用していた時ではありえませんでした。 型を意識してコードを書くので、無理やりなコードは産まれにくいです。
全然難しくない型
(最初は)難しい型は使う必要無し type Pick<T, K extends keyof T> = { [P
in K]: T[P]; };
引数の型と戻り値を書くだけ function sum(a: number, b: number): number { return a
+ b; }
インターフェースを定義するだけ interface Person { name: string; age: number; married: boolean;
} const person: Person = { name: 'xxx', age: 20, married: false };
ね?簡単でしょう?
これだけは守って欲しい
非any三原則 ※非any三原則(ひanyさんげんそく)とは、「 anyをもたない、つくらない、もちこまない」という三つの原則からな る、日本の国是。[要出典]
anyを指定した例 const a: any = 1; const b: any =
'b'; // コンパイラさんが仕事を放棄 const c = a * b;
any = コンパイラがエラーをだす仕事を放棄する anyは我々を救わない anyは危険 anyは闇の魔術 メーデー!メーデー!
闇の魔術に対する防衛術
ソースコードの平和を守ろう // tsconfig.json { "compilerOptions": { "strict": true, } }
tsconfig.jsonとは TypeScriptを使用したプロジェクトのルートディレクトリに配置されてるやつ。 コンパイルオプションなどを設定できる。 先ほどの例では、コンパイルオプションで”strict: true”を指定している。 { "compilerOptions": { "strict": true,
}
strict: true ? “strict: true”は複数のコンパイルオプションが設定される。 特に”noImplicitAny”がまじエクスペクトパトローナム。
noImplicitAny ? 暗黙的なanyの混入を防いでくれる。 明示的にanyしているのを発見したら、レビューで弾こう!
因みにAngularでやるなら Strict Modeが用意されてます。 ng new [project-name] --stricta Angular用のコンパイルオプションも有効化されます。
完全に興味が湧いた後は?
まずは触ってみよう! https://www.typescriptlang.org/play
調べてみよう! • 公式サイト(https://www.typescriptlang.org/) • TypeScript Deep Dive(https://basarat.gitbook.io/typescript/) • サバイバルTypeScript(https://book.yyts.org/) •
TypeScriptの型入門(https://qiita.com/uhyo/items/e2fdef2d3236b9bfe74a)
書籍で学ぼう! https://www.oreilly.co.jp/books/9784873119045/
おしまい。