@Amarok-w

Как сделать замену содержимого элемента?


Есть код, при наведении на элемент, у него внутри появляется круг, но если на него навести то пропадает. Как сделать так чтобы при наведении на круг он всё равно оставался?
  • Вопрос задан
  • 68 просмотров
Пригласить эксперта
Ответы на вопрос 1
@xareyli
Как-то так
const items = document.querySelector('.items');
let currentElem = null;

items.addEventListener('mouseover', (event) => {
  if (currentElem) {
    return;
  }
  
  let target = event.target.closest('.item')

  if (!target) {
    return;
  }

  onEnter(target)
  currentElem = target
})

items.addEventListener('mouseout', (event) => {
  if (!currentElem) {
    return;
  }
  
  let relatedTarget = event.relatedTarget;
  
  while (relatedTarget) {
    if (relatedTarget === currentElem) return;
    
    relatedTarget = relatedTarget.parentNode;
  }
  
  onLeave(currentElem);
  currentElem = null;
})

function onEnter(target) {
  target.insertAdjacentHTML('beforeend', '<div class="circle"></div>')
}

function onLeave(target) {
  target.querySelector('.circle')?.remove();
}
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
22 нояб. 2024, в 08:04
1 руб./за проект
22 нояб. 2024, в 06:06
1500 руб./в час
22 нояб. 2024, в 06:04
1 руб./за проект