Массивы

Содержание

Слайд 2

Массивы

Массив – разновидность объекта, которая предназначена для хранения пронумерованных значений и предлагает

Массивы Массив – разновидность объекта, которая предназначена для хранения пронумерованных значений и
дополнительные методы для удобного манипулирования такой коллекцией.
По сути, массив - это просто переменная, которая отличается тем, что в обычной переменной содержится одно значение, а в массиве может содержаться неограниченное кол-во значений, причём именно в JS они могут быть разного типа в одном массиве. То есть в одном массиве может содержаться элемент типа string, типа number и типа boolean одновременно.

Слайд 3

Создание массива

Массив создаётся практически так же как и обычная привычная нам переменная.

Создание массива Массив создаётся практически так же как и обычная привычная нам

Например, попробуем создать массив с именем arr (задавать ему имя array нельзя, так как это зарезервированное значение в языке Java Script)

Слайд 4

Наполнение массива

В примере на предыдущем слайде мы создали массив arr. В том

Наполнение массива В примере на предыдущем слайде мы создали массив arr. В
примере он абсолютно пустой.
Попробуем наполнить его, причём значениями разного типа, и вывести в нашем документе:

Слайд 5

Элементы массива

Все элементы массива нумеруются автоматически, причем первый элемент является нулевым, а

Элементы массива Все элементы массива нумеруются автоматически, причем первый элемент является нулевым,
не первым элементом. Давайте попробуем вывести первый и третий элемент нашего массива (для этого на самом деле нужно будет вывести элемент 0 и элемент 2):
Результат: вывелось hi и 3.

Слайд 6

Длина массива

Каждый массив имеет свою длину. Для того, чтобы определить длину массива,

Длина массива Каждый массив имеет свою длину. Для того, чтобы определить длину
существует специальная функция.
Сейчас при помощи этой функции выведем в документе длину нашего массива:

Слайд 7

Массивы и циклы

При помощи циклов мы можем работать с массивами. Например,

Массивы и циклы При помощи циклов мы можем работать с массивами. Например, выведем все значения массива:
выведем все значения массива:

Слайд 8

Сортировка пузырьком

Сортировка пузырьком

Слайд 9

Создание массива при помощи цикла:


Создание массива при помощи цикла:

Слайд 10

Как посчитать сумму элементов массива:


Как посчитать сумму элементов массива:

Слайд 11

Многомерные массивы

Многомерные массивы - это массивы, в которых каждым элементом массива является

Многомерные массивы Многомерные массивы - это массивы, в которых каждым элементом массива является другой массив.
другой массив.

Слайд 12

Создаём двумерный массив:


Создаём двумерный массив:

Слайд 13

Обращение к элементам многомерного массива:


Обращение к элементам многомерного массива:

Слайд 14

Как вывести многомерный массив?


Как вывести многомерный массив?

Слайд 15

Методы для работы с массивами

У всех объектов, в том числе и у

Методы для работы с массивами У всех объектов, в том числе и
массивов, есть методы toString () и valueOf( ) .
Метод toString (), будучи вызванный для массива, воз­вращает строку из строковых эквивалентов значений массива, разделенных запятыми.
Метод valueOf ( )- не изменяет исходное содержимое массива и возвращает все элементы массива.

Слайд 16

Метод join

Метод join объединяет элементы массива в строку с указанным разделителем (он будет

Метод join Метод join объединяет элементы массива в строку с указанным разделителем
вставлен между элементами массива).
Разделитель задается параметром метода и не является обязательным. Если он не задан - по умолчанию в качестве разделителя возьмется запятая. Если вы хотите слить элементы массива без разделителя - укажите его как пустую строку ''

Слайд 17

Методы push, pop, shift, unshift

Метод push () принимает любое количество аргументов и

Методы push, pop, shift, unshift Метод push () принимает любое количество аргументов
добавляет их в конец
массива, возвращая его новую длину. Метод рор () извлекает последний элемент
массива, уменьшает длину массива на 1 и возвращает элемент.
Метод shift() удаляет первый элемент массива, возвращая его и уменьшая длину массива на 1.
Метод u n s h i f t (), обратный методу shi ft (): он добавляет любое количество элементов в начало массива и возвращает его новую длину.

Слайд 18

Методы изменения порядка следования элементов

Для изменения порядка следования элементов, уже находящихся в

Методы изменения порядка следования элементов Для изменения порядка следования элементов, уже находящихся
массиве, ис­пользуются методы reverse( ) и sort(). Метод reverse () просто изменяет порядок следования элементов в массиве на обратный, например:
var values = [1, 2, 3, 4, 5 ] ;
values . reverse ();
alert (values); // 5,4, 3,2,1

Слайд 19

Метод sort

По умолчанию метод sort () располагает элементы по возрастанию: наименьшее
значение первым,

Метод sort По умолчанию метод sort () располагает элементы по возрастанию: наименьшее
а наибольшее последним. Чтобы отсортировать массив, он вы­
зывает функцию приведения типов String () для каждого элемента, а затем срав­
нивает возвращенные строки. Это происходит, даже если массив содержит только
числа, например:
var values = [0, 1, 5, 10, 15] ;
values . sort();
alert (values); // 0,1, 10,15, 5

Слайд 20

Методы манипулирования элементами

Над элементами массивов можно выполнять различные операции. Например,
метод concat() позволяет

Методы манипулирования элементами Над элементами массивов можно выполнять различные операции. Например, метод
создать новый массив на основе текущего. Сначала он
создает копию массива, а затем добавляет аргументы в его конец и возвращает
новый массив. Если метод concat () вызван без аргументов, он просто возвращает
копию массива. Если передать в метод concat() один или несколько массивов,
все их элементы будут добавлены в конец результата. Значения, которые не яв­
ляются массивами, просто добавляются в конец итогового массива. Рассмотрим
пример:

Слайд 21

Пример:

var colors = ["red", "green", " Ыuе" ];
var colors2 = colors .

Пример: var colors = ["red", "green", " Ыuе" ]; var colors2 =
concat ( "yellow", [ "Ыасk" , " brown " ]);
alert (colors); // red , green, Ьlue
alert (colors2) ; // red, green, Ыue, yellow, Ыack,brown

Слайд 22

Метод slice

Метод slice ( ) создает массив с одним или более элементами,

Метод slice Метод slice ( ) создает массив с одним или более
уже содержащи­
мися в массиве. Он принимает один или два аргумента: начальную и конечную
позиции элементов, которые нужно возвратить. Если аргумент только один, ме­
тод возвращает все элементы с этой позиции до конца массива. Если аргументов
два, метод возвращает все элементы между начальной и конечной позициями, не
включая конечный элемент. Эта операция никак не влияет на исходный массив.
Рассмотрим пример:

Слайд 23

Пример:
var colors = ["red", " green", "Ыuе", "yellow" , " purple" ];
var

Пример: var colors = ["red", " green", "Ыuе", "yellow" , " purple"
colors2 = colors . slice(1) ;
var colorsЗ = colors . slice(1,4) ;
alert ( colors2) ;
alert ( colorsЗ);

Слайд 24

Самый мощный - метод splice

Самым мощным методом для работы с массивами является

Самый мощный - метод splice Самым мощным методом для работы с массивами
splice ( ) . Он
используется в основном для вставки элементов в середину массива, но есть и два
других способа его применения.

Слайд 25

Удаление

Удаление. Из массива можно удалить любое количество элементов, указав
позицию первого элемента, подлежащего

Удаление Удаление. Из массива можно удалить любое количество элементов, указав позицию первого
удалению, и количество удаляемых
элементов. Например, вызов splice ( 0, 2) удаляет первые два элемента.

Слайд 26

2. Вставка

Вставка. Элементы можно вставить в массив в конкретной позиции, указав три
или

2. Вставка Вставка. Элементы можно вставить в массив в конкретной позиции, указав
более аргументов: начальную позицию, О (количество удаляемых элементов)
и элемент, который нужно вставить. С помощью четвертого, пятого и т. д. пара­
метров можно вставить дополнительные элементы. Например, вызов splice ( 2,
0, " red ", " green») вставляет в массив строки " red " и "green" начиная с позиции 2.

Слайд 27

3. Замена

Замена. При вставке элементов в конкретной позиции можно одновременно
удалить элементы, которые

3. Замена Замена. При вставке элементов в конкретной позиции можно одновременно удалить
уже есть в массиве. Для этого нужно указать три
или более аргументов: начальную позицию, количество удаляемых элементов
и любое количество вставляемых элементов. Вставляемых элементов может
быть больше или меньше, чем удаляемых. Например, вызов splice ( 2, 1, " red ",
"green") удаляет один элемент в позиции 2, а затем вставляет в этой же позиции
строки " red " и "green".

Слайд 28

Удаление элемента:

var colors = ["red", " green", " Ыuе" ]; // удаление

Удаление элемента: var colors = ["red", " green", " Ыuе" ]; //
первого элемента
var removed = colors . splice (0,1);
alert (colors); // greeп, Ыue
alert (removed); // red - массив с одним элементом

Слайд 29

Вставка двух элементов

// вставка двух элементов в позиции 1
removed = colors .

Вставка двух элементов // вставка двух элементов в позиции 1 removed =
splice (1, 0, "yellow" , "oraпge" );
alert (colors); // greeп, yellow, oraпge, Ыue
alert (removed); // пустой массив

Слайд 30

Вставка и удаление

// вставка двух значений и удаление одного
removed = colors .

Вставка и удаление // вставка двух значений и удаление одного removed =
splice (l, 1, " red", " purple " );
alert (colors); // greeп, red, purple, oraпge, Ыue
alert (removed); // yellow - массив с одним элементом

Слайд 31

Задание 1:

Создайте массив, длиной в 6 элементов, каждый из которого больше предыдущего

Задание 1: Создайте массив, длиной в 6 элементов, каждый из которого больше
на 5, после этого найдите среднее значение из этих чисел.

Слайд 32

Задание 2.

Есть массив с неизвестным кол-вом элементов. Как вывести последний элемент?

Задание 2. Есть массив с неизвестным кол-вом элементов. Как вывести последний элемент?

Слайд 33

Задание 3

У нас снова массив с неизвестным кол-вом элементов.
Напишите код, в

Задание 3 У нас снова массив с неизвестным кол-вом элементов. Напишите код,
котором предпоследнему элементу задается значение “предпоследний элемент”.

Слайд 34

Задача 4:

Задача из 5 шагов-строк: Создайте массив styles с элементами «Джаз», «Блюз». Добавьте в

Задача 4: Задача из 5 шагов-строк: Создайте массив styles с элементами «Джаз»,
конец значение «Рок-н-Ролл» Замените предпоследнее значение с конца на «Классика». Код замены предпоследнего значения должен работать для массивов любой длины. Удалите первое значение массива и выведите его alert. Добавьте в начало значения «Рэп» и «Регги». Массив в результате каждого шага: Джаз, Блюз Джаз, Блюз, Рок-н-Ролл Джаз, Классика, Рок-н-Ролл Классика, Рок-н-Ролл Рэп, Регги, Классика, Рок-н-Ролл

Слайд 35

Поиск элемента в массиве

Методы arr.indexOf, arr.lastIndexOf и arr.includes имеют одинаковый синтаксис и

Поиск элемента в массиве Методы arr.indexOf, arr.lastIndexOf и arr.includes имеют одинаковый синтаксис
делают по сути то же самое, что и их строковые аналоги, но работают с элементами вместо символов:
arr.indexOf(item, from) ищет item, начиная с индекса from, и возвращает индекс, на котором был найден искомый элемент, в противном случае -1;
arr.lastIndexOf(item, from) – то же самое, но ищет справа налево.
arr.includes(item, from) – ищет item, начиная с индекса from, и возвращает true, если поиск успешен.

Слайд 36

find и findIndex

let result = arr.find(function(item, index, array) {}
Возвращает элемент, удовлетворяющий условию

find и findIndex let result = arr.find(function(item, index, array) {} Возвращает элемент, удовлетворяющий условию внутри функции.
внутри функции.

Слайд 37

filter

let result = arr.filter(function(item, index, array) {}
Возвращает все элементы, удовлетворяющие условию внутри

filter let result = arr.filter(function(item, index, array) {} Возвращает все элементы, удовлетворяющие условию внутри функции.
функции.

Слайд 38

forEach

arr.forEach(function(item, index, array) {}

forEach arr.forEach(function(item, index, array) {}

Слайд 39

map

let result = arr.map(function(item, index, array) {}
Он вызывает функцию для каждого элемента

map let result = arr.map(function(item, index, array) {} Он вызывает функцию для
массива и возвращает массив результатов выполнения этой функции.

Слайд 40

reduce/reduceRight

let value = arr.reduce(function(previousValue, item, index, array) { // ...
}, [initial]);
Функция применяется

reduce/reduceRight let value = arr.reduce(function(previousValue, item, index, array) { // ... },
по очереди ко всем элементам массива и «переносит» свой результат на следующий вызов.

Слайд 41

Задание 1:

Существует массив из какого-то количества элементов строковых данных. Необходимо создать новый

Задание 1: Существует массив из какого-то количества элементов строковых данных. Необходимо создать
массив из длин каждого из элементов исходного массива.

Слайд 42

Задание 2:

Существует цикл for, который перебирает массив со строковыми и числовыми данными[“Anna”,

Задание 2: Существует цикл for, который перебирает массив со строковыми и числовыми
12, “Sam”, 9, “Kate”, 10, “Ron”, 9] и выводит сначала строки, а затем числа:

Необходимо переписать данный цикл с помощью forEach() метода

Слайд 43

Задание 3:

Существует массив [1, 4, 2, 67, 34, 2, 50, 23, 11,

Задание 3: Существует массив [1, 4, 2, 67, 34, 2, 50, 23,
10, 5, 4, 9, 21] . Необходимо создать новый массив из значений данного, которые больше 10.
Имя файла: Массивы.pptx
Количество просмотров: 32
Количество скачиваний: 0