Проиграть цикл javascript определенное количество раз. Циклы for в JavaScript

Цикл for - наиболее используемый вариант организации цикла в JavaScript.

Его конструкция выглядит так:

For (начало; условие; шаг) { /* тело цикла */ }

Всё на самом деле просто. Давайте рассмотри пример:

Var i; for (i = 1; i

В этом примере:

  • Начало цикла : i = 1 (начиная со значения i = 1)
  • Условие цика : i
  • Шаг цикла : i++ (при каждом шаге цикла i увеличивать на 1)
  • Тело цикла : document.write("

    Выполняется шаг цикла номер:" + "

    "); (выводить на экран сообщение)

Пошаговый алгоритм выполнения этого цикла for, более детально:

  • Начало цикла: переменной i присваивается значение 1. Эта часть цикла выполняется один раз.
  • Проверяется условие цикла (i 5) - конец цикла.
  • Выполняется тело цикла.
  • Выполняется шаг цикла. В шашем случае i++. Он всегда выполняется после тела цикла.
  • Возвращение на пункт 2.
  • Если тело цикла состоит из одной инструкции, то фигурные скобки {...} ставить не обязательно.

    Переменная i после завершения цикла не исчезает. Она продолжает существовать и её значение после завершения цикла будет равно 6.

    Давайте обощим эти данные в новом примере:

    Var i; for (i = 1; i

    Тут для создания тела цикла фигурные скобки не использовались.

    Фигурные скобки {...} образуют блок в JavaScript - это одна из консрукций языка. То есть, если после оператора цикла for стоят фигурные скобки, это значит что обработчик JavaScript должен выполнить весь блок JavaScript.

    Аналогично блоку, в цикле for можно указать функцию. Вот пример:

    For (var i = 1; i

    Но вот при объявлении функции фигурные скобки {...} обязательны. Их отсутствие приведёт к ошибке.

    Обратите внимание, в этом цикле переменная i объявлена в начале цикла: for (var i = 1 ; i

    Пропуск частей for

    Вообще, начало цикла можно и не прописывать:

    Var i = 1; for (; i

    Видите, в начале цикла просто точка с запятой, а цикл нормально работает.

    Также можно убрать шаг:

    Var i = 1; for (; i

    Этот цикл for превратился в аналог цикла while (i

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

    For (i = 10; i--;) { document.write("

    Выполняется шаг цикла: " + i + ".

    "); }

    Так как интерпретатор JavaScript когда ожидает получить логическое значение, любое значение приводит к логическому типу, то когда в результате очередного дикремента переменная i станет равной 0 (ложь), цикл остановится.

    Безконечный цикл for

    Да, да, я знаю что правильно писать бесконечный:)

    Итак, цикл будет безконечный, если условие всегда будет истиной. Вот пример:

    For (var i = 1; i

    В этом примере переменная i будет уменьшаться и никогда не станет больше пяти. Цикл будет выполняться вечно. Попробуйте запустить этот скрипт. У меня Хром "задумался" и ничего не выдал на экран, а продолжал думать и думать.

    Будте внимательны и избегайте случайного создания безконечных циклов.

    Прерывание цикла for

    Для прерывания цикла for, как и для прерывания любого другого цикла, используется команда break . Когда обработчик JavaScript обнаруживает команду break в теле цикла, он останавливает выполнения цикла и начинает выполнять инструцкии сценария, следующие за циклом. если такие имеются.

    В следующем примере мы остановим цикл на третьей итерации (третьем шаге).

    For (var i = 1; i

    Немного усложним пример

    Выполним только 100 итераций безконечного цикла.

    Var $counter = 1; for (var i = 1; i

    Следующая итерация: continue

    Команда continue завершает текущую итерацию и начинает выполнять следующую.

    Директива continue «младшая сестра» директивы break, она останавливает только итерацию, а не весь цикл.

    For (var i = 1; i

    Цикл ниже использует continue , чтобы выводить нечетные значения:

    For (var i = 0; i

    Конечно, нечётные значения можно вывести при помощи такого цикла без директивы continue :

    For (var i = 0; i

    Директивы break / continue в операторе "?"

    Давайте кратко опишем оператор вопросительный знак "? ". Он похож на конструкцию if .

    Логическая конструкция:

    If (условие) { a(); } else { b(); }

    Работает также, как и код с оператором "? ".

    Условие? a() : b(); var i = 2; document.write("

    Часть 1.

    "); if (i == 2) document.write("

    Условие сработало.

    "); else document.write("

    Условие не сработало.

    "); document.write("

    Часть 2.

    "); i == 2 ? document.write("

    Условие сработало.

    ") : document.write("

    Условие не сработало.

    ");

    Так вот, важно , нельзя использовать break/continue справа от оператора "? "

    В JavaScript синтаксические конструкции, не возвращающие значений, запрещено использовать в операторе "? ".

    Нижний пример не рабочий, в нём содержится ошибка:

    For (var i = 0; i

    Метки для break / continue

    Иногда возникает необходимость создавать вложенные циклы. В таком случае во время работы вложенного цикла может возникнуть необходимость остановить родительский цикл или остановить итерацию родительского цикла. Для этого используются метки.

    Вы можете применять метки для обозначения циклов, чтобы затем при помощи break или continue выходить из цикла или продолжать работу цикла с новой итерации.

    Метки - единственный способ для команд break и continue повлиять на выполнение внешнего цикла.

    Инструкция метки (англ. label) используется только вместе с break или continue для альтернативного выхода из цикла.

    Метка имеет синтаксис "имя:", имя метки должно быть уникальным. Метка ставится перед циклом, в той же строке или с переносом строки.

    Аналогично можно в этом месте использовать директиву break . Но в случае её использования, как вы понимаете, выполнение циклов прекратится.

    Var i, j; metka1: for (i = 0; i

    В языке JavaScript нет оператора goto , как в PHP, возможно использовать только метки с break или continue .

    Метки редко используются при программировании на JavaScript, так как считается что они делают код сложнее в чтении ипонимании. При кодировании рекомендуется использовать функции.

    Циклы - простой способ сделать какое-то действие несколько раз. Эта глава руководства JavaScript Guide познакомит вас с различными операторами доступными в JavaScript.

    Вы можете представить цикл в виде компьютеризированной версии игры, где вы говорите кому-то сделать X шагов в одном направлении, затем Y шагов в другом; для примера, идея игры "Иди 5 шагов на восток" может быть выражена в виде цикла:

    Var step; for (step = 0; step < 5; step++) { // Запускается 5 раз, с шагом от 0 до 4. console.log("Идём 1 шаг на восток"); }

    Существует множество различных видов циклов, но все они по сути делают тоже самое: повторяют какое-либо действие несколько раз (не забывайте про нулевой раз повторения, отсчёт в массиве начинается с 0). Различные по строению циклы предлагают разные способы для определения начала и окончания цикла. Для различных задач программирования существуют свои операторы цикла, с помощью которых они решаются намного проще.

    Операторы предназначеные для организации циклов в JavaScript:

    Цикл for

    Цикл for повторяет действия, пока не произойдёт какое-либо специальное событие завершения цикла. Оператор for в JavaScript аналогичен оператору for в Java и C. Объявление оператора for выглядит следующим образом:

    For ([начало]; [условие]; [шаг]) выражения

    При его выполнении происходит следущее:

  • Выполняется выражение начало, если оно указано. Это выражение обычно инициализирует один или несколько счётчиков, но синтаксис позволяет выражению быть любой сложности. Также используется для объявления переменных.
  • Выполняется условие. Если условие истинно, то выполняются выражения. Если оно ложно, цикл for прерывается. Если же условие полностью пропущено, то оно считается истинным.
  • Выполняются выражения. Чтобы выполнить несколько выражений, используются блок-выражение { ... } для группировки выражений.
  • Обновляется шаг, если он есть, а затем управление возвращается к шагу 2.
  • Пример

    В следующей функции есть цикл for , который считает количество выбранных жанров в списке прокрутки (элемент , который позволяет выбрать несколько элементов). Цикл for объявляет переменную i и задаёт ей значение 0. Также он проверяет, что i меньше количества элементов в элементе , выполняет оператор if и увеличивает i на один после каждого прохода цикла.

    Выберите некоторые жанры музыки, а затем нажмите на кнопку ниже: R&B Jazz Blues New Age Classical Opera

    function howMany(selectObject) { var numberSelected = 0; for (var i = 0; i < selectObject.options.length; i++) { if (selectObject.options[i].selected) { numberSelected++; } } return numberSelected; } var btn = document.getElementById("btn"); btn.addEventListener("click", function(){ alert("Выбрано элементов: " + howMany(document.selectForm.musicTypes)) });

    Цикл do...while

    Цикл do...while повторяется пока заданное условие истинно. Оператор do...while имеет вид:

    Do выражения while (условие);

    выражения выполняются пока условие истинно. Чтобы использовать несколько выражений, используйте блок-выражение { ... } , чтобы сгруппировать их. Если условие истинно, выражения выполнятся снова. В конце каждого прохода условие проверяется. Если условие ложно, выполнение приостанавливается и управление передаётся выражению после do...while .

    Пример

    В следующем примере, цикл do выполнится минимум 1 раз и запускается снова, пока i меньше 5.

    Do { i += 1; console.log(i); } while (i < 5);

    Цикл while

    Цикл while выполняет выражения пока условие истинно. Выглядит он так:

    While (условие) выражения

    Если условие становится ложным, выражения в цикле перестают выполняться и управление переходит к выражению после цикла.

    Условие проверяется на истинность до того, как выполняются выражения в цикле. Если условие истинно, выполняются выражения, а затем условие проверяется снова. Если условие ложно, выполнение приостанавливается и управление переходит к выражению после while .

    Чтобы использовать несколько выражений, используйте блок выражение { ... } , чтобы сгруппировать их.

    Пример 1

    Следующий цикл while работает, пока n меньше трёх:

    Var n = 0; var x = 0; while (n < 3) { n++; x += n; }

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

    • После первого прохода: n = 1 и x = 1
    • После второго: n = 2 и x = 3
    • После третьего прохода: n = 3 и x = 6

    После третьего прохода, условие n < 3 становится ложным, поэтому цикл прерывается.

    Пример 2

    Избегайте бесконечных циклов. Убедитесь, что условие цикла в итоге станет ложным; иначе, цикл никогда не прервётся. Выражения в следующем цикле while будут выполняться вечно, т.к. условие никогда не станет ложным:

    While (true) { console.log("Hello, world"); }

    Метка (label)

    Метка представляет собой оператор с индентификатором, который позволяет вам ссылаться на какое-то место в вашей программе. Например, вы можете использовать метку, чтобы обозначить цикл, а затем использовать операторы break или continue , чтобы указать, должна ли программа прерывать цикл или продолжать его выполнение.

    Синтаксис метки следующий:

    Метка: оператор

    Значение метки может быть любым корректным JavaScript индентификатором, не являющимся зарезервированным словом. Оператор , указанный вами после метки может быть любым выражением.

    Пример

    В этом примере, метка markLoop обозначает цикл while .

    MarkLoop: while (theMark == true) { doSomething(); }

    break

    Используйте оператор break , чтобы прерывать цикл, переключать управление или в сочетании с оператором метка.

    • Когда вы используете break без метки, он прерывает циклы while , do-while и for или сразу переключает управление к следующему выражению.
    • Когда вы используете break с меткой, он прерывает специально отмеченное выражение.

    Синтаксис оператора может быть таким:

  • break;
  • break Метка ;
  • Первая форма синтаксиса прерывает цикл совсем или переключает управление; вторая прерывает специально обозначенное выражение.

    Пример 1

    Следующий пример проходит по элементам в массиве, пока не найдёт элемент, чьё значение - theValue:

    For (i = 0; i < a.length; i++) { if (a[i] == theValue) { break; } }

    Пример 2: Прерывание метки var x = 0; var z = 0 labelCancelLoops: while (true) { console.log("Внешний цикл: " + x); x += 1; z = 1; while (true) { console.log("Внутренний цикл: " + z); z += 1; if (z === 10 && x === 10) { break labelCancelLoops; } else if (z === 10) { break; } } } continue

    Оператор continue используется, чтобы шагнуть на шаг вперёд в циклах while , do-while , for или перейти к метке.

    • Когда вы используете continue без метки, он прерывает текущую итерацию циклов while , do-while и for и продолжает выполнение цикла со следующей итерации. В отличие от break , continue не прерывает выполнение цикла полностью. В цикле while он прыгает к условию. А в for увеличивает шаг.
    • Когда вы используете continue с меткой, он применяется к циклу с этой меткой.

    Синтаксис continue может выглядеть так:

  • continue;
  • continue Метка ;
  • Пример 1

    Следующий пример показывает цикл while с оператором continue , который срабатывает, когда значение i равно 3. Таким образом, n получает значения 1, 3, 7 и 12.

    Var i = 0; var n = 0; while (i < 5) { i++; if (i == 3) { continue; } n += i; }

    Пример 2

    Выражение, отмеченное checkiandj содержит выражение отмеченное checkj . При встрече с continue , программа прерывает текущую итерацию checkj и начинает следующую итерацию. Каждый раз при встрече с continue , checkj переходит на следующую итерацию, пока условие возвращает false . Когда возвращается false , после вычисления остатка от деления checkiandj , checkiandj переходит на следующую итерацию, пока его условие возвращает false . Когда возвращается false , программа продолжает выполнение с выражения после checkiandj .

    Если у continue проставлена метка checkiandj , программа может продолжиться с начала метки checkiandj .

    Checkiandj: while (i < 4) { console.log(i); i += 1; checkj: while (j > 4) { console.log(j); j -= 1; if ((j % 2) != 0) { continue checkj; } console.log(j + " чётное."); } console.log("i = " + i); console.log("j = " + j); }

    for...in

    Оператор for...in проходит по всем перечислимым свойствам объекта. JavaScript выполнит указанные выражения для каждого отдельного свойства. Цикл for...in выглядит так:

    For (variable in object) { выражения }

    Пример

    Следующая функция берёт своим аргументом объект и его имя. Затем проходит по всем свойствам объекта и возвращает строку, которая содержит имена свойств и их значения.

    Function dump_props(obj, obj_name) { var result = ""; for (var i in obj) { result += obj_name + "." + i + " = " + obj[i] + "
    "; } result += ""; return result; }

    Для объекта car со свойствами make и model , результатом будет :

    Car.make = Ford car.model = Mustang

    Пример №2

    Также, по ключу можно выводить значение:

    Let obj = {model: "AUDI A8", year: "2019", color: "brown"} for (key in obj) { console.log(`${key} = ${obj}`); } // model = AUDI A8 // year = 2019 // color = brown

    Массивы

    Хотя, очень заманчиво использовать for...in как способ пройтись по всем элементам Array , этот оператор возвращает имя свойств определённых пользователем помимо числовых индексов. Таким образом лучше использовать стандартный for для числовых индексов при взаимодействии с массивами, поскольку оператор for...in проходит по определённым пользователем свойствам в дополнение к элементам массива, если вы изменяете массив, например, добавляете свойства и методы.

    For (variable of object ) { выражения }

    Следующий пример показывает разницу между циклами for...of и for...in . Тогда как for...in проходит по именам свойств, for...of проходит по значениям свойств:

    Let arr = ; arr.foo = "hello"; for (let i in arr) { console.log(i); // выводит "0", "1", "2", "foo" } for (let i of arr) { console.log(i); // выводит "3", "5", "7" }

    Последнее обновление: 08.04.2018

    Циклы позволяют в зависимости от определенных условий выполнять некоторое действие множество раз. В JavaScript имеются следующие виды циклов:

      for..in

      for..of

      while

      do..while

    Цикл for

    Цикл for имеет следующее формальное определение:

    For ([инициализация счетчика]; [условие]; [изменение счетчика]){ // действия }

    Например, используем цикл for для перебора элементов массива:

    Var people = ["Tom", "Alice", "Bob", "Sam"]; for(var i = 0; i= 0; i--){ console.log(people[i]); }

    В данном случае массив выводится с конца, а перебор массива начинается с i = 3 до i = 0.

    for..in

    Цикл for..in предназначен для перебора массивов и объектов. Его формальное определение:

    For (индекс in массив) { // действия }

    Например, переберем элементы массива:

    Var people = ["Tom", "Alice", "Bob", "Sam"]; for(var index in people){ console.log(people); }

    Цикл for...of

    Цикл for...of похож на цикл for...in и предназначен для перебора коллекций, например, массивов:

    Let users = ["Tom", "Bob", "Sam"]; for(let val of users) console.log(val);

    Текущий перебираемый элемент коллекции помещается в переменную val, значение которой затем выводится на консоль.

    Цикл while

    Цикл while выполняется до тех пор, пока некоторое условие истинно. Его формальное определение:

    While(условие){ // действия }

    Опять же выведем с помощью while элементы массива:

    Var people = ["Tom", "Alice", "Bob", "Sam"]; var index = 0; while(index < people.length){ console.log(people); index++; }

    Цикл while здесь будет выполняться, пока значение index не станет равным длине массива.

    do..while

    В цикле do сначала выполняется код цикла, а потом происходит проверка условия в инструкции while. И пока это условие истинно, цикл повторяется. Например:

    Var x = 1; do{ console.log(x * x); x++; }while(x < 10)

    Здесь код цикла сработает 9 раз, пока x не станет равным 10. При этом цикл do гарантирует хотя бы однократное выполнение действий, даже если условие в инструкции while не будет истинно.

    Операторы continue и break

    Иногда бывает необходимо выйти из цикла до его завершения. В этом случае мы можем воспользоваться оператором break :

    < array.length; i++) { if (array[i] > 10) break; document.write(array[i] + "
    "); }

    Данный цикл перебирает все элементы массива, однако последние четыре элемента не будут выведены в браузере, поскольку поверка if (array[i] > 10) прервет выполнение цикла с помощью оператора break, когда перебор массива дойдет до элемента 12.

    Если нам надо просто пропустить итерацию, но не выходить из цикла, мы можем применять оператор continue :

    Var array = [ 1, 2, 3, 4, 5, 12, 17, 6, 7 ]; for (var i = 0; i < array.length; i++) { if (array[i] > 10) continue; document.write(array[i] + "
    "); }

    В этом случае, если программа встретит в массиве число, больше 10, то это число не будет выводиться в браузере.

    Циклы JavaScript обеспечивают многократное выполнение повторяющихся вычислений. Они оптимизируют процесс написания кода, выполняя одну и ту же инструкцию или блок инструкций, образующих тело цикла, заданное число раз (используя переменную-счётчик) или пока заданное условие истинно. Циклы выполняют обход последовательности значений. Однократное выполнение цикла называется итерацией .

    На производительность цикла влияют количество итераций и количество операций, выполняемых в теле цикла каждой итерации.

    В JavaScript существуют следующие операторы цикла:

    1) for используется когда вы заранее знаете, сколько раз вам нужно что-то сделать;
    2) for...in используется для обхода свойств объектов;
    3) while используется когда вы не знаете, сколько раз нужно что-то сделать;
    4) do...while работает аналогично с оператором while . Отличается тем, что do...while всегда выполняет выражение в фигурных скобках, по крайней мере один раз, даже если проверка условия возвращает false .

    Типы циклов в JavaScript, управление циклом 1. Цикл for

    Цикл for используется для выполнения итераций по элементам массивов или объектов, напоминающих массивы, таких как arguments и HTMLCollection . Условие проверяется перед каждой итерацией цикла. В случае успешной проверки выполняется код внутри цикла, в противном случае код внутри цикла не выполняется и программа продолжает работу с первой строки, следующей непосредственно после цикла.

    Следующий цикл выведет на консоль строчку Hello, JavaScript! пять раз.

    For (var i = 0; i < 5; i++) { console.log(i + ": Hello, JavaScript!"); }
    Рис. 1. Результат выполнения цикла for на консоли

    1.1. Как работает цикл for

    Цикл for состоит из трёх разных операций:

    Шаг 1. инициализация var i = 0; — объявление переменной-счётчика, которая будет проверяться во время выполнения цикла. Эта переменная инициализируется со значением 0 . Чаще всего в качестве счётчиков цикла выступают переменные с именами i , j и k .

    Шаг 2. проверка условия i < 5; — условное выражение, если оно возвращает true , тело цикла (инструкция в фигурных скобках) будет выполнено. В данном примере проверка условия идёт до тех пор, пока значение счётчика меньше 5 .

    Шаг 3. завершающая операция i++ — операция приращения счётчика, увеличивает значение переменной var i на единицу. Вместо операции инкремента также может использоваться операция декремента.

    По завершении цикла в переменной var i сохраняется значение 1 . Следующий виток цикла выполняется для for (var i = 1; i < 5; i++) { } . Условное выражение вычисляется снова, чтобы проверить, является ли значение счётчика i всё ещё меньше 5 . Если это так, операторы в теле цикла выполняются ещё раз. Завершающая операция снова увеличивает значение переменной на единицу. Шаги 2 и 3 повторяются до тех пор, пока условие i < 5; возвращает true .

    1.2. Вывод значений массива

    Чтобы вывести значения массива с помощью цикла for , нужно задействовать свойство массива length . Это поможет определить количество элементов в массиве и выполнить цикл такое же количество раз.

    Приведённый ниже скрипт выведет на экран пять сообщений с названиями цветов:

    Var flowers = ["Rose", "Lily", "Tulip", "Jasmine", "Orchid"]; for (var i = 0; i < flowers.length; i++){ alert(flowers[i] + " - это цветок."); }

    Если значение свойства length не изменяется в ходе выполнения цикла, можно сохранить его в локальной переменной, а затем использовать эту переменную в условном выражении. Таким образом можно повысить скорость выполнения цикла, так как значение свойства length будет извлекаться всего один раз за всё время работы цикла.

    Var flowers = ["Rose", "Lily", "Tulip", "Jasmine", "Orchid"], len = flowers.length; for (var i = 0; i

    2. Цикл for...in

    Циклы for...in используются для обхода свойств объектов, не являющихся массивами. Такой обход также называется перечислением . При обходе рекомендуется использовать метод hasOwnProperty() , чтобы отфильтровать свойства, которые были унаследованы от прототипа.

    Для примера создадим объект с помощью литерала объекта.

    Var user = { name: "Alice", age: 25, country: "Russia" }; for (var prop in user) { console.log(prop + ": " + user); }
    Рис. 2. Результат выполнения цикла for...in на консоли

    Предположим, что в сценарии до или после создания объекта user прототип объекта Object был расширен дополнительным методом clone() .

    If (typeof Object.prototype.clone === "undefined") { Object.prototype.clone = function () {}; }

    Так как цепочка наследования прототипа постоянно проверяется интерпретатором, то все объекты автоматически получают доступ к новому методу.

    Рис. 3. Результат повторного выполнения цикла for...in на консоли

    Чтобы избежать обнаружения этого метода в процессе перечисления свойств объекта user , используется метод hasOwnProperty() , который отфильтрует свойства прототипа.

    Var user = { name: "Alice", age: 25, country: "Russia" }; if (typeof Object.prototype.clone === "undefined") { Object.prototype.clone = function () {}; } for (var prop in user) { if (user.hasOwnProperty(prop)) { console.log(prop + ": " + user); } }
    Рис. 4. Результат перечисления свойств объекта с помощью метода hasOwnProperty()

    3. Цикл while

    Цикл while - цикл с предварительной проверкой условного выражения. Инструкция внутри цикла (блок кода в фигурных скобках) будет выполняться в случае, если условное выражение вычисляется в true . Если первая проверка даст результат false , блок инструкций не выполнится ни разу.

    После завершения итерации цикла условное выражение опять проверяется на истинность и процесс будет повторяться до тех пор, пока выражение не будет вычислено как false . В этом случае программа продолжит работу с первой строки, следующей непосредственно после цикла (если таковая имеется).

    Данный цикл выведет на экран таблицу умножения для числа 3:

    Var i = 1; var msg = ""; while (i < 10) { msg+= i + " x 3 = " + (i * 3) + "
    "; i++; } document.write(msg);
    Рис. 5. Результат выполнения цикла while

    4. Цикл do...while

    Цикл do...while; проверяет условие продолжения после выполнения цикла. В отличие от цикла while , в do...while; тело цикла выполняется как минимум один раз, так как условие проверяется в конце цикла, а не в начале. Данный цикл используется реже, чем while , так как на практике ситуация, когда требуется хотя бы однократное исполнение цикла, встречается редко.

    Var result = ""; var i = 0; do { i += 1; result += i + " "; } while (i < 5); document.write(result);
    Рис. 6. Результат выполнения цикла do...while

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

    Var i = 10; do { document.write(i + " "); i++; } while (i < 10);

    5. Бесконечные циклы

    При создании любого цикла можно создать бесконечный цикл, который никогда не завершится. Такой цикл может потенциально продолжать работать до тех пор, пока работает компьютер пользователя. Большинство современных браузеров могут обнаружить это и предложат пользователю остановить выполнение скрипта. Чтобы избежать создания бесконечного цикла, вы должны быть уверены, что заданное условие в какой-то момент вернёт false . Например, следующий цикл задаёт условие, которое никогда не возвращает ложь, так как переменная i никогда не будет меньше 10:

    For (var i = 25; i > 10; i++) { document.write("Это предложение будет выводиться бесконечно...
    "); }

    6. Вложенные циклы

    Цикл внутри другого цикла называется вложенным . При каждой итерации цикла вложенный цикл выполняется полностью. Вложенные циклы можно создавать с помощью цикла for и цикла while .

    For (var count = 1; count < 3; count++) { document.write(count + ". Строка цикла
    "); for (var nestcount = 1; nestcount< 3; nestcount++) { document.write("Строка вложенного цикла
    "); } }
    Рис. 7. Результат выполнения вложенного цикла for

    7. Управление циклом

    Циклом можно управлять с помощью операторов break; и continue; .

    7.1. Оператор break;

    Оператор break; завершает выполнение текущего цикла. Он используется в исключительных случаях, когда цикл не может выполняться по какой-то причине, например, если приложение обнаруживает ошибку. Чаще всего оператор break; является частью конструкции if .

    Когда оператор break; используется без метки, он позволяет выйти из цикла или из инструкции switch . В следующем примере создаётся счётчик, значения которого должны изменяться от 1 до 99 , однако оператор break прерывает цикл после 14 итераций.

    For (var i = 1; i < 100; i++) { if (i == 15) { break; } document.write(i); document.write("
    "); }
    Рис. 8. Результат работы оператора break в цикле for

    Для вложенных циклов оператор break; используется с меткой, с помощью которой завершается работа именованной инструкции. Метка позволяет выйти из любого блока кода. Именованной инструкцией может быть любая инструкция, внешняя по отношению к оператору break; . В качестве метки может быть имя инструкции if или имя блока инструкций, заключенных в фигурные скобки только для присвоения метки этому блоку. Между ключевым словом break; и именем метки не допускается перевод строки.

    Outerloop: for(var i = 0; i < 10; i++) { innerloop: for(var j = 0; j < 10; j++) { if (j > 3) break; // Выход из самого внутреннего цикла if (i == 2) break innerloop; // То же самое if (i == 4) break outerloop; // Выход из внешнего цикла document.write("i = " + i + " j = " + j + "
    "); } } document.write("FINAL i = " + i + " j = " + j + "
    ");

    7.2. Оператор continue;

    Оператор continue; останавливает текущую итерацию цикла и запускает новую итерацию. При этом, цикл while возвращается непосредственно к своему условию, а цикл for сначала вычисляет выражение инкремента, а затем возвращается к условию.

    В этом примере на экран будут выведены все чётные числа:

    Var i; for(i = 1; i

    Есть вопросы?

    Сообщить об опечатке

    Текст, который будет отправлен нашим редакторам: