分割代入
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)のように使うことができます。
最終更新
役に立ちましたか?