原文: https://howtodoinjava.com/typescript/spread-operator/

在 TypeScript 中,可以使用展开运算符(以省略号的形式)来初始化另一个数组或对象中的数组和对象。 您还可以使用展开运算符进行对象分解。

展开运算符与apply()方法

JavaScript 的apply()方法调用具有给定this值的函数,并以array提供参数。 例如,在下面的示例中,两个突出显示的函数调用是等效的。 它们都打印相同的输出。

  1. var numbers = [1, 2, 3, 4, 5];
  2. console.log.apply(console, numbers); //1 2 3 4 5
  3. console.log("1", "2", "3", "4", "5"); //1 2 3 4 5

展开运算符(ECMAScript 6 的一部分)是apply()方法的更好版本。 使用展开运算符,您可以像上面这样写上面的语句。

  1. var numbers = [1, 2, 3, 4, 5];
  2. console.log(...argsArray); //1 2 3 4 5

展开运算符示例

  1. 从另一个数组初始化数组


您可以使用展开运算符以给定的方式从现有数组创建数组。

  1. let origArrayOne = [ 1, 2, 3]; //1,2,3
  2. let origArrayTwo = [ 4, 5, 6]; //4,5,6
  3. //Create new array from existing array
  4. let copyArray = [...origArrayOne]; //1,2,3
  5. //Create new array from existing array + more elements
  6. let newArray = [...origArrayOne, 7, 8]; //1,2,3,7,8
  7. //Create array by merging two arrays
  8. let mergedArray = [...origArrayOne, ...origArrayTwo]; //1,2,3,4,5,6
  1. 从另一个对象初始化对象


您还可以使用展开运算符以给定的方式从现有对象创建对象。

  1. let origObjectOne = {a: 1, b: 2, c: 3}; //{a: 1, b: 2, c: 3}
  2. let origObjectTwo = {d: 4, e: 5, f: 6}; //{d: 4, e: 5, f: 6}
  3. //Create new object from existing object
  4. let copyObject = {...origObjectOne}; //{a: 1, b: 2, c: 3}
  5. //Create new object from existing object + more elements
  6. let newObject = {...origObjectOne, g: 7, h: 8}; //{a: 1, b: 2, c: 3, g: 7, h: 8}
  7. //Create object by merging two objects
  8. let mergedObject = {...origObjectOne, ...origObjectTwo}; //{a: 1, b: 2, c: 3, d: 4, e: 5, f: 6}
  1. 对象解构


解构赋值语法是一个 JavaScript 表达式,可以将数组中的值或对象中的属性解压缩为不同的变量。

  1. function myFunction(x, y, z) {
  2. console.log( x );
  3. console.log( y );
  4. console.log( z );
  5. }
  6. var parametersArray = [0, 1, 2];
  7. myFunction(...parametersArray); //0, 1, 2

将我的问题放在评论部分。

学习愉快!

参考: Mozilla Docs