Кратко
Скопированоclear
очищает таймаут установленный с помощью set
.
Как пишется
Скопированоconst timerId = setTimeout(() => { console.log('Прошла секунда')}, 1000)clearTimeout(timerId)
const timerId = setTimeout(() => { console.log('Прошла секунда') }, 1000) clearTimeout(timerId)
Функция clear
принимает один аргумент – числовой идентификатор таймаута. Этот идентификатор можно получить в результате вызова set
.
Как понять
СкопированоНе всегда бывает необходимо, чтобы отложенный вызов обязательно сработал. clear
прерывает таймер и установленная функция уже не вызовется.
Когда устанавливается таймер, браузер записывает этот идентификатор в свой список активных таймеров. При очищении браузер найдёт таймер по его идентификатору и уберёт из списка.
Мы рекомендуем всегда подчищать таймеры, если они больше не нужны. Даже если в самой функции стоят необходимые проверки и её вызов не приведёт к неожиданным последствиям.
☝️ Упомянутый выше список активных таймеров общий и для таймеров, установленных с помощью set
и для таймеров, установленных с помощью set
. Потому в clear
можно использовать идентификаторы обоих типов таймеров.
Однако для интервалов мы рекомендуем использовать отдельную функцию clear
для лучшей читаемости.
На практике
Скопированосоветует Скопировано
🛠 Связку set
и clear
часто можно увидеть во время реализации всплывающей подсказки. Ниже приводим базовый пример такой функциональности. Этот код можно использовать как стартовый шаблон для ваших наработок.
Создадим HTML-разметку, в которой будет кнопка и скрытая подсказка к этой кнопке.
<button>Наведи на меня</button><div hidden>Подсказка к кнопке</div>
<button>Наведи на меня</button> <div hidden>Подсказка к кнопке</div>
Подсказка будет появляться сразу при наведении мыши на кнопку. Но, если убрать курсор с кнопки, то подсказка исчезнет только через секунду.
const trigger = document.querySelector('button')const hint = document.querySelector('div')let hideTimeoutId = nulltrigger.addEventListener('mouseenter', () => { clearTimeout(hideTimeoutId) hint.hidden = false})trigger.addEventListener('mouseleave', () => { hideTimeoutId = setTimeout(() => { hint.hidden = true }, 1000)})
const trigger = document.querySelector('button') const hint = document.querySelector('div') let hideTimeoutId = null trigger.addEventListener('mouseenter', () => { clearTimeout(hideTimeoutId) hint.hidden = false }) trigger.addEventListener('mouseleave', () => { hideTimeoutId = setTimeout(() => { hint.hidden = true }, 1000) })