- Многомерные массивы в JS
- Создание многомерного массива
- Пример 1
- Пример 2
- Доступ к элементам многомерного массива
- Добавление элементов в многомерный массив
- С помощью push()
- С помощью квадратных скобок
- С помощью splice()
- Удаление элементов из многомерного массива
- С помощью pop()
- С помощью splice()
- Перебор элементов многомерного массива
- С помощью forEach()
- С помощью for. of
- С помощью цикла for
Многомерные массивы в JS
Многомерный массив — это массив, в котором содержится другой массив или другие массивы.
// пример многомерного массива const data = [[1, 2, 3], [1, 3, 4], [4, 5, 6]];
Создание многомерного массива
Пример 1
let studentsData = [['Андрей', 24], ['Настя', 23], ['Даня', 24]];
Пример 2
// одномерные массивы let student1 = ['Андрей', 24]; let student2 = ['Настя', 23]; let student3 = ['Даня', 24]; // многомерный массив let studentsData = [student1, student2, student3];
Оба примера создают одинаковые мнгомерные массивы.
Доступ к элементам многомерного массива
Получить элемент многомерного массива можно обратившись к нему по индексу или индексам.
let x = [ ['Андрей', 24], ['Настя', 23], ['Даня', 24] ]; // получаем первый элемент — это массив console.log(x[0]); // Вывод: ["Андрей", 24] // получаем первый элемент первого «внутреннего» массива console.log(x[0][0]); // Вывод: Андрей // получаем второй элемент третьего «внутреннего» массива console.log(x[2][1]); // Вывод: 24
Многомерный массив x из нашего примера можно представить как таблицу с 3 строками и 2 столбцами.
Добавление элементов в многомерный массив
Добавить элемент в многомерный массив можно с помощью метода push() или с помощью квадратных скобок [] и доступа по индексу. Еще вариант — использовать метод splice() , но он используется реже.
С помощью push()
Давайте добавим элемент во «внешний» массив с помощью метода push() .
let studentsData = [['Андрей', 24], ['Настя', 23],]; studentsData.push(['Даня', 24]); console.log(studentsData); // Вывод: [["Андрей", 24], ["Настя", 23], ["Даня", 24]
Теперь добавим элемент во «внутренний» массив.
let studentsData = [['Андрей, 24], ['Настя', 23],]; studentsData[1].push('привет'); console.log(studentsData); // Вывод: [['Андрей, 24], ['Настя', 23, "привет"]]
С помощью квадратных скобок
// using index notation let studentsData = [['Андрей', 24], ['Настя', 23],]; studentsData[1][2] = 'привет'; console.log(studentsData); // Вывод: [["Андрей", 24], ["Настя", 23, "привет"]]
С помощью splice()
let studentsData = [['Андрей', 24], ['Настя', 23],]; // добавляем элемент на позицию с индексом 1 studentsData.splice(1, 0, ['Даня', 24]); console.log(studentsData); // Вывод: [["Андрей", 24], ["Даня", 24], ["Настя", 23]]
Удаление элементов из многомерного массива
Удалить элемент в многомерный массив можно с помощью метода pop() или с помощью метода splice() .
С помощью pop()
Давайте удалим элемент из «внешнего» массива с помощью метода pop() .
let studentsData = [['Андрей', 24], ['Настя', 23],]; studentsData.pop(); console.log(studentsData); // Вывод: [["Андрей", 24]]
Теперь удалим элемент из внутреннего массива с помощью pop() .
let studentsData = [['Андрей', 24], ['Настя', 23]]; studentsData[1].pop(); console.log(studentsData); // Вывод: [["Андрей", 24], ["Настя"]]
Примечание. Минус метода pop() — он умеет удалять только последний элемент.
С помощью splice()
А вот метод splice() позволяет удалять элемент по определенному индексу.
let studentsData = [['Андрей', 24], ['Настя', 23],]; // удаляем элемент «внешнего» массива с индексом 1 — «внутренний» массив studentsData.splice(1,1); console.log(studentsData); // Вывод: [["Андрей", 24]]
Перебор элементов многомерного массива
С помощью forEach()
Перебрать элементы многомерного массива можно с помощью метода forEach() .
let studentsData = [['Андрей', 24], ['Настя', 23],]; // перебираем элементы массива studentsData studentsData.forEach((student) => < student.forEach((data) =>< console.log(data); >); >);
Первый метод forEach() используется для перебора элементов «внешнего» массива, а второй forEach() — для перебора элементов «внутреннего» массива.
С помощью for. of
Еще вариант для перебора — использовать цикл for. of для прохода по многомерному массиву.
let studentsData = [['Андрей', 24], ['Настя', 23],]; for (let i of studentsData) < for (let j of i) < console.log(j); >>
С помощью цикла for
Перебрать элемента многомерного массива можно и классическим способом — с помощью цикла for .
let studentsData = [['Андрей', 24], ['Настя', 23],]; // проходим по элементам «внешнего» массива for(let i = 0; i < studentsData.length; i++)< // вычисляем длину «внутреннег» массива let innerArrayLength = studentsData[i].length; // проходим по элементам «внутреннего» массива for(let j = 0; j < innerArrayLength; j++) < console.log(studentsData[i][j]); >>
СodeСhick.io — простой и эффективный способ изучения программирования.
2023 © ООО «Алгоритмы и практика»