Есть ли аналог foreach в JS?

Веб-программирование — почти всегда это создание кода, с использованием нескольких языков программирования. Зная одни языки, вы ищите знакомые аналоги там, где не так твердо стоите на ногах.

Есть ли в javascript оператор цикла foreach (аналог в PHP)?

И да и нет. Но скорее — да. :)

Foreach предназначен для перебора элементов массива. Потому он является методом объекта Array.

Array.forEach(callback)

В следующем примере показано, как он может использоваться.

В колбэк-функцию передаются три параметра — элемент массива, ключ и сам массив.

FOR — IN цикл

В отличии от простого цикла for-in позволяет итерировать свойства объекта, либо массива с не полностью заселенными индексами.

Вот пример такого массива.

Перебрать его элементы можно вот так:

Важный момент состоит в том, что порядок свойств объекта или элементов массива при таком переборе может оказаться неожиданным (т.е. выведет не «5 6 7», а в другом порядке).

FOR — OF цикл

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

Как видите, все варианты имеют свои особенности и ограничения. Остаётся выбрать тот из них, который подходит именно для вашей задачи.

Написать комментарий

Мало букафф? Читайте есчо !

Создание контейнера DIV средствами чистого js

Август 5, 2018 г.

Иногда я возвращаюсь к практикам без использования jQuery, работая с DOM на чистом js. В таком контексте его называют vanila js. Давайте рассмотрим пример создания DIV контейнера, определения его свойств, пользуясь только javascript без библиотек-оберток. ...

Читать

Перебор атрибутов HTML элемента в javascript

Февраль 17, 2016 г.

За использованием библиотеки jQuery как то забываешь о базовых свойствах и методах DOM  в javascript. Как получить весь набор аттрибутов HTML элемента? Получим ссылку на элемент HTML документа каким либо образом: [crayon-60d24f1f6b6bd390362927/] ...

Читать

 

Комментарии к «Есть ли аналог foreach в JS?»

Понравилась статья? Есть вопросы? - пишите в комментариях.



Комментарий: