Array.prototype.slice()
相同:
```js
const [a, b, ...arr] = [1, 2, 3, 4, 5, 7];
console.log(a, b); // 1, 2
console.log(arr); // [3, 4, 5, 7]
```
变量a
与b
分别获取了数组的前两个元素的值。之后,因为rest
操作符的存在,arr
获取了原数组剩余的元素的值,并构成了一个新的数组。
rest
操作只能对数组列表最后的元素起作用。这意味着你不能使用rest
操作符来截取原数组中间元素的子数组。
rest
操作符来进行一个Array.prototype.slice
相同的操作。使得arr
是原数组source
除开前两个元素的子数组。
arr
应该为[3,4,5,6,7,8,9,10]
testString: assert(arr.every((v, i) => v === i + 3) && arr.length === 8);
- text: 没有使用Array.slice()
。
testString: getUserInput => assert(!getUserInput('index').match(/slice/g));
- text: 使用了解构赋值。
testString: assert(code.replace(/\s/g, '').match(/\[(([_$a-z]\w*)?,){1,}\.\.\.arr\]=list/i));
```