* feat(tools): add seed/solution restore script * chore(curriculum): remove empty sections' markers * chore(curriculum): add seed + solution to Chinese * chore: remove old formatter * fix: update getChallenges parse translated challenges separately, without reference to the source * chore(curriculum): add dashedName to English * chore(curriculum): add dashedName to Chinese * refactor: remove unused challenge property 'name' * fix: relax dashedName requirement * fix: stray tag Remove stray `pre` tag from challenge file. Signed-off-by: nhcarrigan <nhcarrigan@gmail.com> Co-authored-by: nhcarrigan <nhcarrigan@gmail.com>
66 lines
1.8 KiB
Markdown
66 lines
1.8 KiB
Markdown
---
|
|
id: 587d7b7a367417b2b2512b12
|
|
title: Copy Array Items Using slice()
|
|
challengeType: 1
|
|
forumTopicId: 301158
|
|
dashedName: copy-array-items-using-slice
|
|
---
|
|
|
|
# --description--
|
|
|
|
The next method we will cover is `slice()`. Rather than modifying an array, `slice()` copies or *extracts* a given number of elements to a new array, leaving the array it is called upon untouched. `slice()` takes only 2 parameters — the first is the index at which to begin extraction, and the second is the index at which to stop extraction (extraction will occur up to, but not including the element at this index). Consider this:
|
|
|
|
```js
|
|
let weatherConditions = ['rain', 'snow', 'sleet', 'hail', 'clear'];
|
|
|
|
let todaysWeather = weatherConditions.slice(1, 3);
|
|
// todaysWeather equals ['snow', 'sleet'];
|
|
// weatherConditions still equals ['rain', 'snow', 'sleet', 'hail', 'clear']
|
|
```
|
|
|
|
In effect, we have created a new array by extracting elements from an existing array.
|
|
|
|
# --instructions--
|
|
|
|
We have defined a function, `forecast`, that takes an array as an argument. Modify the function using `slice()` to extract information from the argument array and return a new array that contains the elements `'warm'` and `'sunny'`.
|
|
|
|
# --hints--
|
|
|
|
`forecast` should return `["warm", "sunny"]`
|
|
|
|
```js
|
|
assert.deepEqual(
|
|
forecast(['cold', 'rainy', 'warm', 'sunny', 'cool', 'thunderstorms']),
|
|
['warm', 'sunny']
|
|
);
|
|
```
|
|
|
|
The `forecast` function should utilize the `slice()` method
|
|
|
|
```js
|
|
assert(/\.slice\(/.test(code));
|
|
```
|
|
|
|
# --seed--
|
|
|
|
## --seed-contents--
|
|
|
|
```js
|
|
function forecast(arr) {
|
|
// Only change code below this line
|
|
|
|
return arr;
|
|
}
|
|
|
|
// Only change code above this line
|
|
console.log(forecast(['cold', 'rainy', 'warm', 'sunny', 'cool', 'thunderstorms']));
|
|
```
|
|
|
|
# --solutions--
|
|
|
|
```js
|
|
function forecast(arr) {
|
|
return arr.slice(2,4);
|
|
}
|
|
```
|