- 13 полезных приёмов по работе с массивами в JavaScript, которые могут вам пригодиться
- 1. Как в массиве оставить только уникальные значения
- 2. Как заменить значения в массиве
- 3. Как трансформировать массив, не используя метод map()
- 4. Как быстро очистить массив
- 5. Как преобразовать массив в объект
- 6. Как заполнить массив одинаковыми значениями
- 7. Как объединить более двух массивов
- 8. Как найти пересечение двух массивов
- 9. Как удалить ложные значения из массива
- 10. Как получить рандомное значение массива
- 11. Как развернуть массив в обратную сторону
- 12. Метод lastIndexOf()
- 13. Как просуммировать все значения в массиве
- Заключение
- Как заменить элемент в массиве JavaScript?
- Array.prototype.indexOf и присвоение
- Array.prototype.map
- Array.prototype.indexOf и Array.prototype.splice
- Заключение
13 полезных приёмов по работе с массивами в JavaScript, которые могут вам пригодиться
Массивы являются одной из самых популярных структур данных в JavaScript, потому что они используются для хранения данных. Кроме этого, массивы дают много возможностей для работы с этими самыми данными. Понимая, что для тех, кто находится в начале пути изучения JavaScript, массивы являются одной из самых основных тем, в этой статье я хотел бы познакомить вас с некоторыми полезными трюками, о которых вы могли не знать. Давайте начнем.
1. Как в массиве оставить только уникальные значения
Это очень популярный вопрос во время интервью на позицию Javascript-разработчика. Вот быстрое и простое решение этой задачки. Для начала вам нужно получить уникальные значения массива, для этого можно использовать new Set() (прим. перев.: структура данных Set хранит только уникальные значения). Далее нужно преобразовать структуру данных Set в массив. Я хочу познакомить вас с двумя способами, как это можно сделать: первый – с помощью метода from() , второй – с помощью оператора spread ( «…» ).
const fruits = ['banana', 'apple', 'orange', 'watermelon', 'apple', 'orange', 'grape', 'apple']; // Первый метод const uniqueFruits = Array.from(new Set(fruits)); console.log(uniqueFruits); // вернет ['banana', 'apple', 'orange', 'watermelon', 'grape'] // Второй метод const uniqueFruits2 = [. new Set(fruits)]; console.log(uniqueFruits2); // вернет ['banana', 'apple', 'orange', 'watermelon', 'grape']
2. Как заменить значения в массиве
Бывают такие ситуации, когда нужно заменить значения в массиве другими значениями. Для этого существует хороший метод, о котором вы, возможно, не знали – метод splice(start, value to remove, values to add) , где start – номер индекса, начиная с которого мы хотим удалить элементы массива, value to remove – число элементов, которые мы хотим удалить, а values to add – элементы, которые мы хотим вставить на место удаленных:
const fruits = ['banana', 'apple', 'orange', 'watermelon', 'apple', 'orange', 'grape', 'apple']; fruits.splice(0, 2, 'potato', 'tomato'); console.log(fruits); // вернет ["potato", "tomato", "orange", "watermelon", "apple", "orange", "grape", "apple"]
3. Как трансформировать массив, не используя метод map()
Наверное, все знают метод массива map() , но есть и другое решение, которое может быть использовано для получения аналогичного эффекта и чистого кода. Для этого мы можем воспользоваться методом from() :
const friends = [ < name: 'John', age: 22 >, < name: 'Peter', age: 23 >, < name: 'Mark', age: 24 >, < name: 'Maria', age: 22 >, < name: 'Monica', age: 21 >, < name: 'Martha', age: 19 >, ] const friendsNames = Array.from(friends, () => name); console.log(friendsNames); // вернет ['John', 'Peter', 'Mark', 'Maria', 'Monica', 'Martha']
4. Как быстро очистить массив
Например, у нас есть массив, в котором много элементов. Нам нужно его очистить (неважно для какой цели), при этом мы не хотим удалять элементы один за другим. Это очень просто сделать одной строчкой кода. Чтобы очистить массив, нам нужно установить длину массива в 0, и всё!
const fruits = ['banana', 'apple', 'orange', 'watermelon', 'apple', 'orange', 'grape', 'apple']; fruits.length = 0; console.log(fruits); // вернет []
5. Как преобразовать массив в объект
Бывает такая ситуация: у нас есть массив, но нам нужен объект (опять неважно для какой цели) с этими данными, и самый быстрый способ преобразовать массив в объект – это использовать оператор spread ( «. « ):
const fruits = ['banana', 'apple', 'orange', 'watermelon', 'apple', 'orange', 'grape', 'apple']; const fruitsObj = < . fruits >; console.log(fruitsObj); // вернет
6. Как заполнить массив одинаковыми значениями
Бывают разные ситуации, когда мы хотим создать массив и заполнить его некоторыми значениями, или нам нужен массив с одинаковыми значениями. Метод fill() для подобных задач является отличным решением:
const newArray = new Array(10).fill('1'); console.log(newArray); // вернет ["1", "1", "1", "1", "1", "1", "1", "1", "1", "1"]
7. Как объединить более двух массивов
Вы знаете, как объединить массивы в один, не используя метод concat() ? Существует простой способ объединить любое количество массивов в один массив одной строчкой кода. Как вы, вероятно, уже поняли, оператор spread ( «. « ) является довольно полезным инструментом при работе с массивами, как и в этом случае:
const fruits = ['apple', 'banana', 'orange']; const meat = ['poultry', 'beef', 'fish']; const vegetables = ['potato', 'tomato', 'cucumber']; const food = [. fruits, . meat, . vegetables]; console.log(food); // вернет ["apple", "banana", "orange", "poultry", "beef", "fish", "potato", "tomato", "cucumber"]
8. Как найти пересечение двух массивов
С этой задачей вы можете столкнуться на любом JavaScript-собеседовании, потому что ее решение показывает ваши знания методов массива, а также то, как вы мыслите. Чтобы найти общие значения двух массивов, мы будем использовать один из ранее рассмотренных методов в этой статье, чтобы убедиться, что значения в массиве, который мы проверяем, не дублируются. Кроме этого, мы воспользуемся методами filter() и includes() . В результате мы получим массив с элементами, которые представлены в обоих массивах:
const numOne = [0, 2, 4, 6, 8, 8]; const numTwo = [1, 2, 3, 4, 5, 6]; const duplicatedValues = [. new Set(numOne)].filter(item => numTwo.includes(item)); console.log(duplicatedValues); // вернет [2, 4, 6]
9. Как удалить ложные значения из массива
Для начала, давайте определим ложные значения. В Javascript ложными значениями являются: false , 0, «», null , NaN и undefined . Теперь мы можем выяснить, как удалить такие значения из нашего массива. Для достижения этой цели нам потребуется метод filter() :
const mixedArr = [0, 'blue', '', NaN, 9, true, undefined, 'white', false]; const trueArr = mixedArr.filter(Boolean); console.log(trueArr); // вернет ["blue", 9, true, "white"]
10. Как получить рандомное значение массива
Иногда нам нужно выбрать рандомное значение массива. Чтобы решение было простым, коротким и быстрым, мы можем получить случайный номер индекса в соответствии с длиной массива. Посмотрите на этот пример:
const colors = ['blue', 'white', 'green', 'navy', 'pink', 'purple', 'orange', 'yellow', 'black', 'brown']; const randomColor = colors[(Math.floor(Math.random() * (colors.length)))]; console.log(randomColor); // вернет рандомный цвет из массива
11. Как развернуть массив в обратную сторону
Когда нам нужно «перевернуть» наш массив, нет необходимости создавать его через сложные циклы и функции, потому что есть простой метод массива reverse() , который делает все это за нас, и одной строчкой кода мы можем «перевернуть» наш массив:
const colors = ['blue', 'white', 'green', 'navy', 'pink', 'purple', 'orange', 'yellow', 'black', 'brown']; const reversedColors = colors.reverse(); console.log(reversedColors); // вернет ["brown", "black", "yellow", "orange", "purple", "pink", "navy", "green", "white", "blue"]
12. Метод lastIndexOf()
В JavaScript есть интересный метод lastIndexOf(elem) , который позволяет найти индекс последнего вхождения элемента elem . Например, если наш массив имеет дублированные значения, мы можем найти позицию последнего вхождения в него. Взгляните на следующий пример кода:
const nums = [1, 5, 2, 6, 3, 5, 2, 3, 6, 5, 2, 7]; const lastIndex = nums.lastIndexOf(5); console.log(lastIndex); // вернет 9
13. Как просуммировать все значения в массиве
Еще один популярный вопрос во время собеседования на позицию JavaScript-разработчика. Сумму всех элементов можно найти одной строчкой кода, если знать метод reduce() :
const nums = [1, 5, 2, 6]; const sum = nums.reduce((x, y) => x + y); console.log(sum); // вернет 14
Заключение
В этой статье я познакомил вас с 13 полезными приёмами, которые помогут вам писать чистый и краткий код. Кроме этого, не забывайте, что есть много различных трюков, которые вы можете использовать в Javascript и которые стоит изучить не только для работы с массивами, но и для других структур данных. Я надеюсь, что вам понравились решения, представленные в статье, и вы будете использовать их для улучшения процесса разработки.
Как заменить элемент в массиве JavaScript?
Иногда нам может потребоваться заменить элемент в массиве JavaScript.
В этой статье мы рассмотрим, как заменить элемент в массиве JavaScript.
Array.prototype.indexOf и присвоение
Мы можем использовать метод indexOf массива JavaScript, чтобы найти индекс заданного значения в массиве.
Затем мы можем использовать индекс, чтобы присвоить этому индексу новое значение.
Например, мы можем написать:
const arr = [523, 353, 334, 31, 412]; const index = arr.indexOf(353); if (index !== -1) < arr[index] = 1010; >console.log(arr)
Мы вызываем arr.indexOf с искомым значением.
Он вернет индекс первого экземпляра значения, если он существует, или -1 в противном случае.
Итак, если index не равно -1, то мы можем заменить значение по данному индексу новым, присвоив его, как мы это делали в блоке if .
Array.prototype.map
Мы можем использовать метод map для возврата нового массива с записями существующего массива, сопоставленными с новыми значениями.
Чтобы использовать это для замены одного или нескольких экземпляров значения, мы можем написать:
const arr = [523, 353, 334, 31, 412]; const mapped = arr.map(a => a == 353 ? 1010 : a) console.log(mapped)
Мы вызываем map с помощью обратного вызова, который проверяет, является ли значение a , которое проходит итерацию, равным 353.
Если это так, мы заменяем это на 1010.
В противном случае мы просто возвращаем существующее значение.
Array.prototype.indexOf и Array.prototype.splice
Мы также можем использовать метод splice массива JavaScript для замены значения по данному индексу новым.
Например, мы можем написать:
const arr = [523, 353, 334, 31, 412]; const index = arr.indexOf(353); if (index !== -1) < arr.splice(index, 1, 1010); >console.log(arr)
Таким же образом получаем индекс 353.
Но вместо присвоения значения мы вызываем splice с index элемента, который нужно удалить.
1 во втором аргументе означает, что мы удаляем 1 элемент.
И третий аргумент — это значение, на которое мы заменяем элемент.
Итак, arr то же самое, что и в первом примере.
Заключение
Мы можем использовать методы массива для замены объекта по данному индексу другим значением.