테스트 사이트 - 개발 중인 베타 버전입니다

javascript 질문이요 채택완료

morrie 5년 전 조회 1,292

데스크탑 버전에서는 .click 가 적용이 되는데

모바일버전에서는 .click로 하면 터치시 반응이 없고 mouseenter로 하면 클릭했을때 화면이 나타나긴 하는데 나타난 화면을 눌렀을때 사라지지가 않아요.

 

제가 원하는건 모바일에서 버튼을 누르면 나타나고 나타난 화면을 누르면 사라지는걸 원하는데 코드를 어떻게 바꿔야 가능할까요?

// 상단메뉴 검색 영역  //     $('#menuArea > li > div').each(function (index) {         $('#menuArea > li').eq(index).click(function(){             $('#menuArea > li > div').eq(index).stop().slideDown(400, 'easeOutQuad');         });         $('#menuArea > li').eq(index).mouseleave(function(){             $('#menuArea > li > div').eq(index).stop().slideUp(400, 'easeOutQuad');         });     });

    // 모바일 상단메뉴 검색 영역  //     $('#menuArea-m > li > div').each(function (index) {         $('#menuArea-m > li').eq(index).mouseenter(function(){             $('#menuArea-m > li > div').eq(index).stop().slideDown(400, 'easeOutQuad');         });         $('#menuArea-m > li').eq(index).mouseleave(function(){             $('#menuArea-m > li > div').eq(index).stop().slideUp(400, 'easeOutQuad');         });     });

댓글을 작성하려면 로그인이 필요합니다.

답변 1개

채택된 답변
+20 포인트
5년 전

모바일은 아래의 이벤트 입니다.

 

touchstart    손가락 닿을 때 발생

touchmove   손가락이 닿은 채 움직일 때 발생

touchend     손가락을 뗄 때 발생

 

간혹 mouseenter 가 touchend 랑 같이 발생하긴 하니까 두개를 같은 코드로 넣어주면 됩니다.

로그인 후 평가할 수 있습니다

답변에 대한 댓글 1개

m
morrie
5년 전
아 다르게 사용해야 하는거였군요. 답변 감사합니다~

댓글을 작성하려면 로그인이 필요합니다.

답변을 작성하려면 로그인이 필요합니다.

로그인