1.7 KiB
1.7 KiB
id | title | challengeType | forumTopicId | dashedName |
---|---|---|---|---|
587d7b7b367417b2b2512b17 | 使用展開運算符合並數組 | 1 | 301156 | combine-arrays-with-the-spread-operator |
--description--
展開語法(spread)的另一個重要用途是合併數組,或者將某個數組的所有元素插入到另一個數組的任意位置。 我們也可以使用 ES5 的語法連接兩個數組,但只能讓它們首尾相接。 而展開語法可以讓這樣的操作變得極其簡單:
let thisArray = ['sage', 'rosemary', 'parsley', 'thyme'];
let thatArray = ['basil', 'cilantro', ...thisArray, 'coriander'];
thatArray
會有值 ['basil', 'cilantro', 'sage', 'rosemary', 'parsley', 'thyme', 'coriander']
使用展開語法,我們就可以很方便的實現一個用傳統方法會寫得很複雜且冗長的操作。
--instructions--
我們已經定義了一個返回 sentence
變量的 spreadOut
函數。 請修改這個函數,利用 spread 使該函數返回數組 ['learning', 'to', 'code', 'is', 'fun']
。
--hints--
spreadOut
應返回 ["learning", "to", "code", "is", "fun"]
。
assert.deepEqual(spreadOut(), ['learning', 'to', 'code', 'is', 'fun']);
spreadOut
函數裏應用到展開語法。
assert.notStrictEqual(spreadOut.toString().search(/[...]/), -1);
--seed--
--seed-contents--
function spreadOut() {
let fragment = ['to', 'code'];
let sentence; // Change this line
return sentence;
}
console.log(spreadOut());
--solutions--
function spreadOut() {
let fragment = ['to', 'code'];
let sentence = ['learning', ...fragment, 'is', 'fun'];
return sentence;
}