分割代入
TypeScriptは以下の分割(Destructuring)をサポートしています(文字通り、de-structuringから来ています。つまり、構造を分解します)。
オブジェクトの分割
配列の分割
分割は、構造化(structuring)の反対と考えてください。それが簡単な理解です。JavaScriptで構造を作る方法はオブジェクトリテラルです。下記に例を示します:
JavaScriptに組み込まれている素晴らしい構造化のサポートがなければ、必要に応じて新しいオブジェクトを作成することは、非常に面倒なことだったでしょう。分割(Destructuring)の機能はデータを取り出すために、同じような利便性をもたらしてくれるものです。
オブジェクトの分割
分割は1行で行うことができるので非常に便利です。それ以外の方法では複数行のコードが必要です。次の場合を考えてみましょう。
ここでは、分解が無ければ、rect
からx、y、width、height
を1つずつ取得する必要があります。
展開した変数を、新しい変数名に割り当てるには、次のようにします。
さらに、分割を使用して構造体の深いデータを取得することもできます。次の例で示します。
オブジェクトの分割でスプレッド演算子(Restパラメータ)を使う
あるオブジェクトから任意の数の要素を取得し、残った要素をスプレッド演算子を使って取得することができます。
一般的なユースケースは、特定のプロパティを無視することです。例:
配列の分割
一般的なプログラミングの質問では、このようなものがあります:「3つ目の変数を使用せずに2つの変数を交換する方法は?」。TypeScriptでの解決策はこうです:
配列の分割は、事実上コンパイラが[0], [1], ...
などとしていることに注意してください。なので、これらの値が存在することは保証されていません。
配列の分割でスプレッド演算子(Restパラメータ)を使う
配列から任意の数の要素を取得し、残りの要素を、スプレッド演算子を使って配列として取得することができます。
配列の分割で一部の要素を無視する
あなたは、その場所を空のままにして、つまり代入の左側に, ,
を残すだけで、特定の要素を無視することができます。例:
生成されるJavaScript
ES5以前をターゲットにしてコンパイルして生成されるJavaScriptでは、一時変数が使われます。
まとめ
分割(Destructuring)は、行数を減らし、開発者の意図を明確にすることで、コードの可読性と保守性を高めてくれます。配列の分割を使うことにより、配列をタプル(Tuple)のように使うことができます。
最終更新