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