javascript 질문이요

javascript 질문이요

QA

javascript 질문이요

본문

데스크탑 버전에서는 .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

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

 

touchstart    손가락 닿을 때 발생

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

touchend     손가락을 뗄 때 발생

 

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

답변을 작성하시기 전에 로그인 해주세요.
전체 169
QA 내용 검색

회원로그인

(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1404호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT