Adding/Removing elements
push (...items)
add items
to the end
Copy const arr = [1, 2, 3];
arr.push(4);
// arr = [1, 2, 3, 4]
pop ()
extracts an element from the end
Copy const arr = [1, 2, 3];
arr.pop();
// arr = [1, 2]
unshift (...items)
add items
to the beginning (bad for performance)
Copy const arr = [1, 2, 3];
arr.unshift(0);
// arr = [0, 1, 2, 3]
shift ()
extracts from the beginning
Copy const arr = [1, 2, 3];
arr.shift();
// arr = [2, 3]
concat (...items)
returns a new array: copy of the current array + items
Copy const arr = [1, 2, 3];
const newArr = arr.concat(4, 5);
const newArr2 = newArr.concat([6, 7]);
// newArr2 = [1, 2, 3, 4, 5, 6, 7]
splice (pos, count, ...items)
at index pos
deletes count
elements and inserts items
Copy const arr = ["a", "*", "*", "d"];
arr.splice(1, 2, "b", "c");
// arr = ['a', 'b', 'c', d']
slice (start, end)
creates a new array, copies elements from index start
till end
(not inclusive) into it
Copy const arr = [1, 2, 3, 4, 5];
const newArr = arr.slice(1, 4);
// newArr = [2, 3, 4]
Search among elements
indexOf / lastIndexOf (item, pos)
look for item
starting from index pos
, return it's index or -1 if not found. Method lastIndexOf()
searches from right to left
Copy const arr = [10, 20, 20, 30];
const first = arr.indexOf(20); // first = 1
const last = arr.lastIndexOf(20); // last = 2
includes (value)
returns true if the array has value, else false
Copy const arr = [10, 20, 30, 40];
const n = arr.includes(15); // false
find / findIndex (func(item, index, arr))
func()
is called for each element of the array. If the func()
returns true, the search is interrupted and item is returned, else - undefined
Copy const arr = [1, 13, 23, 43, 56, 71, 97]
const evenNum = arr.find(item => {
return % 2 === 0
})
// evenNum = 56
filter (func(item, index, arr))
the method is similar to find()
, but filter()
returns an array of all matching elements
Copy const arr = [1, 2, 3, 4, 5, 6, 7];
const evenArr = arr.filter((item) => {
return item % 2 === 0;
}); // evenArr = [2, 4, 6]
Iteration of elements
forEach (func(item, index, array))
calls func()
for every element in array, does not return anything
Copy const arr = [1, 2, 3];
arr.forEach((item, index, arr) => {
console.log(item, index, arr);
});
// 1 0 [1, 2, 3]
// 2 1 [1, 2, 3]
// 3 2 [1, 2, 3]
map (func(item, index, array))
calls the func()
for each element of the array and returns the array of results
Copy const arr = [1, 2, 3, 4, 5];
const newArr = arr.map((item) => {
return item * 10;
});
// newArr = [10, 20, 30, 40, 50]
sort (func())
sorts the array changing it's element order, func()
defining the sorting order (optional).
Copy const arr = [25, 7, 13 31]
arr.sort((a, b) => {
return a - b
})
// arr = [7, 13, 25, 31]
reverse ()
reverse the order of the elements of the current array
Copy const arr = [1, 2, 3, 4, 5];
arr.reverse();
// arr = [5, 4, 3, 2, 1]
join (separator) / string.split(separator)
convert an array to string / a string to array
Copy const str = "one, two, three, four";
const arr = str.split(", ");
// arr = ["one", "two", "three", "four"]
const newStr = arr.join("-");
// newStr = "one-two-three-four"
reduce / reduceRight (func(accumulator, current, index, array), initial)
calculate a single value over the array by calling func()
for each element and passing an intermediate result between the calls
Copy const arr = [1, 2, 3, 4, 5];
const sumFromElements = arr.reduce((sum, current) => {
return sum + current;
}, 0);
// sumFromElements = 15
Bonus
Array.isArray (variable)
checks variable
for being an array, return true/false
Copy const a = [1, 2, 3];
const b = 17;
Array.isArray(a); // true
Array.isArray(b); // false
some / every (fn())
The function fn()
is called on each element of the array similar to map()
. If any/all results are true - return true, otherwise - false
Copy const arr = [1, 2, 3, 4, 5];
const even = (element) => element % 2 === 0;
arr.some(even); // true
const arr2 = [8, 20, 100, 29, 10, 13];
const lessThanForty = (element) => element < 40;
arr2.every(lessThanForty); // false
fill (value, start, end)
fills the array with repeating value
from start
to end
positiion
Copy const arr = ["a", "b", "c", "d"];
const filledArr = arr.fill("*", 2, 4);
// filledArr = ['a', 'b', '*', '*']
flat (depth)
create a new flat array from a multidimensioanl array
Copy const arr = [0, 1, 2, [[[3, 4]]]];
const newArr = arr.flat(2);
// newArr = [0, 1, 2, [3, 4]]