169 похожих чатов

Привет всем! Помогите, пожалуйста, с вопросом про eventы. Использую TypeScript

и React.js
Задача: мне нужно на hover показывать перевод слова, для этого eventListener обращается к АПИ словаря. Мне бы хотелось делать запросы, только если юзер оставляет мышку на слове в течение какого-то времени.
Я попробовала в MouseEnter делать setTimeout, а в MouseLeave очищать его:
MouseEnter:
if (hintText === "") {
filterTimer = setTimeout(() => {
positionHint();
getTranslation(props.word).then(data => setHintText(data[0]));
}, 1000);
MouseLeave:
if (filterTimer !== null) {
clearTimeout(filterTimer);
}

Видимо, я что-то упускаю и в Network я всё равно вижу запросы, даже если мышка уже не там. Как можно избежать обращения к API, если мышки уже нет на элементе? Спасибо:)

1 ответов

7 просмотров

Попробуй каждые 100мс записывать в счётчик с помощью колбэка. А затем, если накопилось определенное время - делать обращение к апи. Так же можно запомнить на каком элементе ты считал - и при уводе мышки с этого элемента - очистить счетчик

Похожие вопросы

Обсуждают сегодня

Ребят в СИ можно реализовать ООП?
Николай
32
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный  TFilestream  не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
16
У меня задача: написать брокер сообщений. Очереди и потребители. Очереди поддерживают приоритеты. Очередь отдает сообщения, только обработчикам с соответствующими характеристи...
Aleksandr Filippov
2
добрый день. Подскажите, есть сайт на 1.4.7 и я хочу обновиться, особо ничего не меняя. мне выбирать версию 1.4.35 или третью ветку? и можно ли обновлять "как есть", или нужно...
Digital Cat
12
народ, плиз хелп, всю голову сломал себе уже... разве может быть так, что GetProcAddress( GetModuleHandle( "kernel32.dll" ), "SetThreadDescription" ) вернёт ненулевое значение...
Iluha Companets
12
Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Всем доброго вечера. Разрабатываю 32 раз. приложение в Delphi. Столкнулся с тем, что стандартный TFilestream не работает с большим файлом > 2 ГБайт (после вызова функции see...
Vadim Gl
8
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Карта сайта