Учебник по JS

ГЛАВНАЯ JS Введение JS Куда Вывод JS Заявления JS JS-синтаксис JS-комментарии JS-переменные JS Пусть Константа JS JS-операторы JS-арифметика Назначение JS JS-типы данных JS-функции JS-объекты JS-события JS-строки Строковые методы JS Поиск строки JS Шаблоны строк JS JS-номера Методы номеров JS JS-массивы Методы массива JS Сортировка массива JS Итерация массива JS Константа массива JS JS-даты Форматы даты JS Методы получения даты JS Методы установки даты JS JS-математика JS Случайный JS Булевы значения Сравнение JS JS-условия JS-переключатель JS цикл для Цикл JS для входа Цикл JS для Цикл JS во время Перерыв JS JS-итерации JS-наборы JS-карты JS Typeof Преобразование типов JS JS побитовый JS регулярное выражение JS-ошибки Область JS JS-подъем Строгий режим JS JS это ключевое слово Функция стрелки JS JS-классы JS JSON JS-отладка Руководство по стилю JS Лучшие практики JS JS-ошибки JS-производительность Зарезервированные слова JS

JS-версии

JS-версии JS 2009 (ES5) JS 2015 (ES6) JS 2016 JS 2017 JS 2018 JS IE/пограничный История JS

JS-объекты

Определения объектов Свойства объекта Методы объекта Отображение объекта Средства доступа к объектам Конструкторы объектов Прототипы объектов Итерации объектов Наборы объектов Карты объектов Ссылка на объект

JS-функции

Определения функций Параметры функции Вызов функции Вызов функции Функция Применить Закрытие функций

JS-классы

Введение в класс Наследование классов Статический класс

JS асинхронный

Обратные вызовы JS JS асинхронный JS-обещания JS асинхронный/ожидание

JS HTML DOM

Дом Введение DOM-методы Документ DOM DOM-элементы DOM HTML DOM-формы ДОМ CSS DOM-анимации События ДОМ Слушатель событий DOM DOM-навигация DOM-узлы Коллекции DOM Списки узлов DOM

Спецификация браузера JS

JS-окно JS-экран Местоположение JS История JS JS-навигатор Всплывающее оповещение JS JS Тайминг JS-куки

JS-веб-API

Введение в веб-API API веб-форм API истории веб-поиска API веб-хранилища API веб-работника API веб-выборки API веб-геолокации

JS АЯКС

Введение в АЯКС AJAX XMLHttp АЯКС-запрос AJAX-ответ XML-файл AJAX АЯКС PHP АЯКС АСП База данных AJAX AJAX-приложения Примеры AJAX

JS JSON

Введение в JSON Синтаксис JSON JSON против XML Типы данных JSON Анализ JSON Строковая JSON JSON-объекты JSON-массивы JSON-сервер JSON PHP JSON HTML JSON JSONP

JS против JQuery

Селекторы jQuery JQuery HTML jQuery CSS JQuery DOM

JS-графика

JS-графика JS Холст JS сюжет JS Chart.js JS Google Диаграмма JS D3.js

JS-примеры

JS-примеры JS HTML DOM JS HTML-ввод HTML-объекты JS HTML-события JS JS-браузер JS-редактор JS-упражнения JS-викторина JS-сертификат

JS-ссылки

Объекты JavaScript HTML DOM-объекты


Асинхронный JavaScript

"Я закончу позже!"

Функции, работающие параллельно с другими функциями, называются асинхронными.

Хорошим примером является JavaScript setTimeout().

Асинхронный JavaScript

Примеры, использованные в предыдущей главе, были очень упрощены.

Целью примеров была демонстрация синтаксиса callback-функций:

Пример

function myDisplayer(something) {
  document.getElementById("demo").innerHTML = something;
}

function myCalculator(num1, num2, myCallback) {
  let sum = num1 + num2;
  myCallback(sum);
}

myCalculator(5, 5, myDisplayer);

В приведенном выше примере myDisplayerэто имя функции.

Он передается в myCalculator()качестве аргумента.

В реальном мире обратные вызовы чаще всего используются с асинхронными функциями.

Типичный пример — JavaScript setTimeout().


Ожидание тайм-аута

При использовании функции JavaScript setTimeout()вы можете указать функцию обратного вызова, которая будет выполняться по тайм-ауту:

Пример

setTimeout(myFunction, 3000);

function myFunction() {
  document.getElementById("demo").innerHTML = "I love You !!";
}

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

myFunctionпередается в setTimeout()качестве аргумента.

3000 — это количество миллисекунд до истечения времени ожидания, поэтому myFunction()вызов будет выполнен через 3 секунды.

Когда вы передаете функцию в качестве аргумента, помните, что нельзя использовать круглые скобки.

Правильно: setTimeout(myFunction, 3000);

Неправильный: setTimeout (моя функция (), 3000);

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

Пример

setTimeout(function() { myFunction("I love You !!!"); }, 3000);

function myFunction(value) {
  document.getElementById("demo").innerHTML = value;
}

В приведенном выше примере function(){ myFunction("I love You !!!"); } используется в качестве обратного вызова. Это полная функция. Полная функция передается в setTimeout() в качестве аргумента.

3000 — это количество миллисекунд до истечения времени ожидания, поэтому myFunction()вызов будет выполнен через 3 секунды.


Ожидание интервалов:

При использовании функции JavaScript setInterval()вы можете указать функцию обратного вызова, которая будет выполняться для каждого интервала:

Пример

setInterval(myFunction, 1000);

function myFunction() {
  let d = new Date();
  document.getElementById("demo").innerHTML=
  d.getHours() + ":" +
  d.getMinutes() + ":" +
  d.getSeconds();
}

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

myFunctionпередается в setInterval()качестве аргумента.

1000 — это количество миллисекунд между интервалами, поэтому myFunction()будет вызываться каждую секунду.


Ожидание файлов

Если вы создаете функцию для загрузки внешнего ресурса (например, сценария или файла), вы не можете использовать содержимое до его полной загрузки.

Это идеальное время для использования обратного вызова.

В этом примере загружается файл HTML ( mycar.html) и отображается файл HTML на веб-странице после полной загрузки файла:

Ожидание файла:

function myDisplayer(some) {
  document.getElementById("demo").innerHTML = some;
}

function getFile(myCallback) {
  let req = new XMLHttpRequest();
  req.open('GET', "mycar.html");
  req.onload = function() {
    if (req.status == 200) {
      myCallback(this.responseText);
    } else {
      myCallback("Error: " + req.status);
    }
  }
  req.send();
}

getFile(myDisplayer);

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

myDisplayerпередается в getFile()качестве аргумента.

Ниже приведена копия mycar.html:

mycar.html


<img src="img_car.jpg" alt="Nice car" style="width:100%">

<p>A car is a wheeled, self-powered motor vehicle used for transportation.
Most definitions of the term specify that cars are designed to run primarily on roads, to have seating for one to eight people, to typically have four wheels.</p>

<p>(Wikipedia)</p>