• 로그인
  • 장바구니에 상품이 없습니다.

home2 게시판 JavaScript, TS 게시판 10 분 캐러셀에 스와이프 기능 만들기

10 분 캐러셀에 스와이프 기능 만들기

2 글 보임 - 1 에서 2 까지 (총 2 중에서)
  • 글쓴이
  • #72889

    송승욱
    참가자
    캐러셀에 스와이프 기능 만들기는 이상없이 했는데 더 확장해 보고 싶어
    오토바이 그림에서 다음으로 마우스 이동을 해보니 되지 않더라구요
    
    그래서 오토바이에도 이벤트 걸어주고  -200에 동적으로 이동할 수 있게 수정했는데 잘 안되네요
    혹시 무슨 문제가 있을까요?
    그냥 혼자 짜본 소스입니다.
    
    
           let startIdx = 0;
            let clickChk = false;
            let moveChk  = false;
            var calcVal  = 0;
            
            $('.slide-box').on('mousedown', function(e){
               startIdx = e.clientX;
               clickChk = true;
               console.log('startOrginIdx=' +  startIdx);    
            });
            
            $('.slide-box').on('mousemove', function(e){
               if(clickChk == true){
                   console.log('clientX =' +  e.clientX); //좌측으로 갈수록 작아지고(양수), 우측으로 갈수록 커짐(음수)
                   console.log('startIdx=' +  startIdx);
                   console.log('moveX=' +  (e.clientX - startIdx));
                   
                   var selIdx  = $(e.target).parent().index() + 1; //index 0부터 시작하는 부분을 계산을 위해 1부터 시작
                   var sumIdx  = $(e.target).parent().length;
                   
                   
                   $('.slide-container').css('transform', `translateX(${e.clientX - startIdx}px )`);
     
                   calcVal = selIdx * -100;
                   console.log("calcVal=" + calcVal);
                   
                   if(e.clientX - startIdx < -100){
                       moveChk = true;
                   }else{
                       moveChk = false;
                   }
               }
            });
            
            $('.slide-box').on('mouseup', function(e){
               clickChk = false;
            
               console.log("clickChk="+ clickChk);    
               console.log("moveChk ="+ moveChk);
                
               if(moveChk){
                  $('.slide-container').css('transition', 'all 0.5s').css('transform', 'translateX('+ calcVal +'vw)');
               }else{
                  $('.slide-container').css('transition', 'all 0.5s').css('transform', 'translateX(0vw)'); 
               }
                
               setTimeout(()=>{
                   $('.slide-container').css('transition', 'none');
               }, 500)    
                
            });
    
     
    #72893

    codingapple
    키 마스터
    어떻게 안됩니까 
    .slide-box말고 오토바이사진에 이벤트리스너 달아봅시다
2 글 보임 - 1 에서 2 까지 (총 2 중에서)
  • 답변은 로그인 후 가능합니다.

About

현재 월 700명 신규수강중입니다.

  (09:00~20:00) 빠른 상담은 카톡 플러스친구 코딩애플 (링크)
  admin@codingapple.com
  이용약관, 개인정보처리방침
ⓒ Codingapple, 강의 예제, 영상 복제 금지
top

© Codingapple, All rights reserved. 슈퍼로켓 에듀케이션 / 서울특별시 강동구 고덕로 19길 30 / 사업자등록번호 : 212-26-14752 온라인 교육학원업 / 통신판매업신고번호 : 제 2017-서울강동-0002 호 / 개인정보관리자 : 박종흠