2022.05.12(更新日: 2024.08.08)
TypeScript 学習 part9
data:image/s3,"s3://crabby-images/f763d/f763dc4396ef43250b9773b9d40dc811a074469b" alt=""
はじめに
こちらの本でTypeScriptの学習を進めています。
data:image/s3,"s3://crabby-images/97d59/97d591fe282f471cbf543dca69b42711032091b1" alt=""
前回は、ユーザーがゲームを選択できるようにしました。今回は、その続きです。
コミット履歴はこちら
行ったこと
ゲーム終了後にゲームを変更できるようにした
ゲーム終了後に、最初に選んだゲームを変更することが出来なかったので、ゲーム変更ができるようにしました。
before
【ゲーム開始時】 hit and blowか、jankenのどちらかを選ぶ
data:image/s3,"s3://crabby-images/dfe1e/dfe1e099367ec6f3c9d977ffe05abab6b7aa2569" alt=""
【ゲーム中】 選択したゲームで遊ぶ
data:image/s3,"s3://crabby-images/5e4db/5e4db4b34b5d7ae7e4c40684ad0289978684428d" alt=""
【ゲーム終了後】 最初に選択したゲームで遊ぶか、ゲームを中止するかの2択
data:image/s3,"s3://crabby-images/447d5/447d5023f1fb4299b581afeb14b47bbc6e18b5c8" alt=""
after
ゲーム終了後に、次に遊ぶゲームを変更できるようにしました。
data:image/s3,"s3://crabby-images/7622c/7622c161cd47c8ffc8fc1ece9b9bda7f30819469" alt=""
change gameという定数を追加して、
const nextActions = ['play again', 'change game', 'exit'] as const
playメソッド内で、ユーザーがchange gameを選択した時の条件分岐を追加しました。
private async play() {
//省略
const action = await promptSelect<NextAction>('ゲームを続けますか?', nextActions)
if (action === 'play again') {
await this.play()
} else if (action === 'change game') {
await this.select()
await this.play()
} else if (action === 'exit') {
this.end()
} else {
const neverValue: never = action
throw new Error(`${neverValue} is an invalid action.`)
}
}
コードのリファクタリング
before
type GameStore = {
'hit and blow': HitAndBlow
'janken': Janken
}
after
type GameStore = {
[key in GameTitle]: HitAndBlow | Janken
}
抽象クラスの作成
クラスの宣言
abstract class Game {
abstract setting(): Promise<void>
abstract play(): Promise<void>
abstract end(): void
}
クラスの利用
class HitAndBlow implements Game {
//省略
}
class Janken implements Game {
//省略
}
次回
次回は、ついにchapter4の「ブラウザで動くアプリケーションを作ってみよう」に入っていきます!
投稿ID : 3035
コメントを残す