87 lines
2.4 KiB
Markdown
87 lines
2.4 KiB
Markdown
---
|
|
id: 587d78b2367417b2b2512b0f
|
|
title: Elimina elementos de un arreglo con pop() y shift()
|
|
challengeType: 1
|
|
forumTopicId: 301165
|
|
dashedName: remove-items-from-an-array-with-pop-and-shift
|
|
---
|
|
|
|
# --description--
|
|
|
|
Tanto `push()` como `unshift()` tienen métodos correspondientes que son casi opuestos funcionales: `pop()` y `shift()`. Como ya habrás adivinado, en lugar de agregar, `pop()` *elimina* un elemento al final de un arreglo, mientras que `shift()` elimina un elemento al principio. La diferencia clave entre `pop()` y `shift()` y sus primos `push()` y `unshift()`, es que ninguno de los dos métodos toma parámetros, y cada uno sólo permite modificar un arreglo por un solo elemento a la vez.
|
|
|
|
Echemos un vistazo:
|
|
|
|
```js
|
|
let greetings = ['whats up?', 'hello', 'see ya!'];
|
|
|
|
greetings.pop();
|
|
```
|
|
|
|
`greetings` tendrá el valor `['whats up?', 'hello']`.
|
|
|
|
```js
|
|
greetings.shift();
|
|
```
|
|
|
|
`greetings` tendrá el valor `['hello']`.
|
|
|
|
También podemos devolver el valor del elemento eliminado con cualquiera de los dos métodos así:
|
|
|
|
```js
|
|
let popped = greetings.pop();
|
|
```
|
|
|
|
`greetings` tendrá el valor `[]` y `popped` tendría el valor `hello`.
|
|
|
|
# --instructions--
|
|
|
|
Hemos definido una función, `popShift`, el cual toma un arreglo como argumento y devuelve un nuevo arreglo. Modifica la función, usando `pop()` y `shift()`, para eliminar el primer y el último elemento del arreglo, y asignar los elementos eliminados a sus correspondientes variables, de modo que el arreglo que se devuelva contenga sus valores.
|
|
|
|
# --hints--
|
|
|
|
`popShift(["challenge", "is", "not", "complete"])` debe devolver `["challenge", "complete"]`
|
|
|
|
```js
|
|
assert.deepEqual(popShift(['challenge', 'is', 'not', 'complete']), [
|
|
'challenge',
|
|
'complete'
|
|
]);
|
|
```
|
|
|
|
La función `popShift` debe utilizar el método `pop()`
|
|
|
|
```js
|
|
assert.notStrictEqual(popShift.toString().search(/\.pop\(/), -1);
|
|
```
|
|
|
|
La función `popShift` debe utilizar el método `shift()`
|
|
|
|
```js
|
|
assert.notStrictEqual(popShift.toString().search(/\.shift\(/), -1);
|
|
```
|
|
|
|
# --seed--
|
|
|
|
## --seed-contents--
|
|
|
|
```js
|
|
function popShift(arr) {
|
|
let popped; // Change this line
|
|
let shifted; // Change this line
|
|
return [shifted, popped];
|
|
}
|
|
|
|
console.log(popShift(['challenge', 'is', 'not', 'complete']));
|
|
```
|
|
|
|
# --solutions--
|
|
|
|
```js
|
|
function popShift(arr) {
|
|
let popped = arr.pop(); // Change this line
|
|
let shifted = arr.shift(); // Change this line
|
|
return [shifted, popped];
|
|
}
|
|
```
|