Объединение двух функций Pure JS

#javascript

Вопрос:

Как я могу объединить эти две функции в одну? Теперь у меня есть две функции, которые делают одно и то же: закрывают окно поиска на сайте — нажатием escape и нажатием снаружи определенного .

     searchOverlay.addEventListener('keydown', function(event){
        if(event.key === "Escape"){
            body.classList.remove('search-opened');
            event.stopPropagation();
        }
    });

    searchOverlay.addEventListener('click', function (e) {
        if (e.target.closest('.search-inner') === null) {
            body.classList.remove('search-opened');
            e.stopPropagation();
        }
    });
}
 

Ответ №1:

Вы даже можете просто создать прослушиватель событий, который поддерживает оба случая

 function removeSearchOpenedClass(event) {
  if (event.key === "Escape" || !event.target.closest(".search-inner")) {
    body.classList.remove('search-opened');
    event.stopPropagation(); 
  }
}
searchOverlay.addEventListener('keydown', removeSearchOpenedClass)
searchOverlay.addEventListener('click', removeSearchOpenedClass)
 

Ответ №2:

Вы можете объявить функцию и вызвать ее в обоих обратных вызовах.

 function doStuff(e){
    body.classList.remove('search-opened');
    e.stopPropagation();
}

searchOverlay.addEventListener('keydown', function(event){
    if(event.key === "Escape"){
        doStuff(event)
    }
});

searchOverlay.addEventListener('click', function (e) {
    if (e.target.closest('.search-inner') === null) {
        doStuff(e)
    }
});