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
そのコレクション合ってる?
Search
akatsuki1910
September 19, 2023
0
20
そのコレクション合ってる?
akatsuki1910
September 19, 2023
Tweet
Share
More Decks by akatsuki1910
See All by akatsuki1910
後輩に伝えたいこと
akatsuki1910
0
2
難解(かもしれない)言語
akatsuki1910
1
29
Reactのチュートリアルをしよう3
akatsuki1910
0
13
クソドメインを取ろう
akatsuki1910
0
29
Reactのチュートリアルをしよう2
akatsuki1910
0
14
HTMLとCSSとコンポーネント
akatsuki1910
0
17
Reactのチュートリアルをしよう
akatsuki1910
0
16
第3回 TypeScriptを使おう
akatsuki1910
0
10
第2回 TypeScriptを使おう
akatsuki1910
0
21
Featured
See All Featured
A Tale of Four Properties
chriscoyier
157
23k
Scaling GitHub
holman
458
140k
How To Stay Up To Date on Web Technology
chriscoyier
789
250k
BBQ
matthewcrist
85
9.4k
The Cult of Friendly URLs
andyhume
78
6.1k
Making Projects Easy
brettharned
116
5.9k
Faster Mobile Websites
deanohume
305
30k
How STYLIGHT went responsive
nonsquared
95
5.2k
The World Runs on Bad Software
bkeepers
PRO
65
11k
What’s in a name? Adding method to the madness
productmarketing
PRO
22
3.2k
Building Adaptive Systems
keathley
38
2.3k
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
44
9.3k
Transcript
そのコレクション合ってる? らり
コレクションとは コレクションとは、値をまとめて管理するオブジェクトのことである なんとなくで作り、なんとなくで保管する箱ではありません コードの読みやすさや、保守のしやすさにも繋がります
配列の基礎の形 「[]」を使うか、Arrayコンストラクタを作る
readonly 型を宣言する際にreadonlyをつけることにより、破壊的変更が出来ない配列を作ること が出来る
readonly ただ、多次元配列を用意する際は、各配列の宣言時にreadonlyをつける必要がある
as const わざわざreadonlyを付けるのはめんどくさいため、as constというものをつける これにより、ネストがあるものでも全てreadonlyがついた状態と同じにできる
as const 型をつける時は、「satisfies」をつける そのまま型注釈を付けちゃうと、as constが抜ける
Setを使う 重複した値を使わない時、Setを使うと明示的 例として、何か重複無しの値を宣言するとなった際、宣言ミスを防げる
Setを使う もちろんreadonlyは存在する ただ、専用の型がある
Setの注意点 「順番」は存在するけど、「順序」は存在しないため、インデックスでアクセスできない (forEachで回すと入れた順に値が出てくる) sortやfilterがないため、毎度配列に直す必要がある そのため、配列操作を沢山行うのであれば、使い方が間違っているか、Setを使うべきで はない場合である
余談 配列のindexは文字列でもアクセス出来る場面がある typescriptではindexが数値でないとエラーを出してくれるが、以下のように出してくれな い時がある これは、元々JSが配列のindexを内部的に文字列にするため、問題ないためである https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/Array
余談 そのため、for inのようにkeyが文字列で返ってくるものでも受け付ける 以下の例だと、変数iはstring型である
余談2 for inは「キーが文字列であるオブジェクトの列挙可能プロパティすべてに対して、継承さ れた列挙可能プロパティも含めて反復処理を行います」とある通り、indexを0から順に 調べて出力してくれる訳ではない そのため、以下のような結果が返る場面があるため、使うのは控えた方がよい
前提知識 : 連想配列 自動的に割り当てられる数字をキーとして持つかわりに、自由に任意の文字列を割り振 ることができる配列 連想リストや辞書などとも呼ばれる 他言語ではListやHashMapという名前で使われている
オブジェクトの基礎の形 「{}」で宣言する キーとバリューが対になったもの(プロパティ)の集合である プロパティへは、ドット記法とブラケット記法の2パターンのアクセス方法がある
readonly readonlyは存在する ただ、ネストが下がると効かなくなるため、全てにかけたい場合はas constを使う
Mapを使う 実は連想配列はオブジェクトで作るべきではなく、Mapを使った方がいい時が多い というのも、オブジェクトは連想配列を作るためにあるものではないからである https://qiita.com/raccy/items/816a322fb330193e788b
Mapを使う また、オブジェクトは連想配列を扱うためとしてはあまり最適化されているわけではない オブジェクトインジェクション攻撃や既定キーがあったりと、オブジェクトの作り方や使い 方をきちんと把握してないと危険な場面があるため、考えることが多い それに比べ、Mapでは上記のような問題はほぼ考えなくてよい https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/Map
Mapを使う もちろんreadonlyは存在する ただ、専用の型がある
Mapの注意点 keyがプリミティブ型じゃないと色々とややこしい なので、ちゃんと型をつけることで解決する
Mapの注意点 最初の初期値の用意の仕方がjson形式ではないため、直観的でない そのため、可読性を求めるために、json形式で用意したデータをMapに変えてから使う という方法がある
総括 初期宣言して、その後中の値が変更されてほしくないのであれば、readonlyをつける 重複した値を使用しない、配列操作をしないのであれば、Setを用いるという選択肢があ る 連想配列にはオブジェクトを使っても良いが、Mapを使った方が得られる恩恵が大きい
課題 課題1 翻訳用オブジェクトを使用しやすい形にしてください 欲しいものは、翻訳用オブジェクトと、そのkeyの型です 課題2 タイトルのテキストが入った配列を使用しやすい形にしてください 欲しいものは、タイトルのテキストが入った配列と、そのタイトルのunionの型です