JavaScript Обратный вызов
"Я перезвоню позже!"
Обратный вызов - это функция, переданная в качестве аргумента другой функции.
Этот метод позволяет функции вызывать другую функцию
Функция обратного вызова может запускаться после завершения другой функции
Последовательность функций
Функции JavaScript выполняются в той последовательности, в которой они вызываются. Не в той последовательности, в которой они определены.
В этом примере будет отображаться сообщение "До свидания":
Пример
function myFirst() {
myDisplayer("Hello");
}
function
mySecond() {
myDisplayer("Goodbye");
}
myFirst();
mySecond();
В этом примере будет отображаться "Привет":
Пример
function myFirst() {
myDisplayer("Hello");
}
function
mySecond() {
myDisplayer("Goodbye");
}
mySecond();
myFirst();
Последовательный контроль
Иногда вам нужно лучше контролировать, когда выполнять функцию.
Предположим, вы хотите произвести расчет, а затем отобразить результат.
Вы можете вызвать функцию калькулятора (myCalculator), сохранить результат, а затем вызвать другую функцию (myDisplayer) для отображения результата:
Пример
function myDisplayer(some) {
document.getElementById("demo").innerHTML = some;
}
function myCalculator(num1, num2) {
let sum = num1 + num2;
return sum;
}
let result = myCalculator(5, 5);
myDisplayer(result);
Или вы можете вызвать функцию калькулятора (myCalculator), и позволить функции калькулятора вызвать функцию отображения (myDisplayer):
Пример
function myDisplayer(some) {
document.getElementById("demo").innerHTML
= some;
}
function myCalculator(num1, num2) {
let sum = num1 + num2;
myDisplayer(sum);
}
myCalculator(5, 5);
Проблема с первым примером, приведенным выше, заключается в том, что вам нужно вызвать две функции для отображения результата.
Проблема со вторым примером состоит в том, что вы не можете предотвратить отображение результата функцией калькулятора.
Пришло время сделать обратный звонок.
Обратные вызовы JavaScript
Обратный вызов - это функция, переданная в качестве аргумента другой функции.
Используя обратный вызов, вы можете вызвать функцию калькулятора (myCalculator) с помощью обратного вызова и позволить функции калькулятора выполнить обратный вызов после завершения расчета:
Пример
function myDisplayer(some) {
document.getElementById("demo").innerHTML
= some;
}
function myCalculator(num1, num2, myCallback) {
let sum = num1 + num2;
myCallback(sum);
}
myCalculator(5, 5, myDisplayer);
В приведенном выше примере myDisplayer это имя функции.
Он передается myCalculator() в качестве аргумента.
Когда вы передаете функцию в качестве аргумента, помните, что нельзя использовать скобки.
Правильно: myCalculator(5, 5, myDisplayer);
Неправильно: myCalculator(5, 5, myDisplayer());
Когда использовать обратный звонок?
Приведенные выше примеры не очень интересны.
Они упрощены, чтобы научить вас синтаксису обратного вызова.
Обратные вызовы действительно блестают в асинхронных функциях, где одна функция должна ждать другой функции (например, ждать загрузки файла).
Асинхронные функции рассматриваются в следующей главе.
