메뉴 건너뛰기

2016.12.22 20:25

bxslider 멈춤현상

조회 수 10112 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
1번과 2번을 같이 처리 지금은 업데이트된 버전이 나온걸로 알고 있음

1. bxslider 는 슬라이드 애니메이션 동작할때 css translate3d 와 jquery animate를 사용한다.

ios webview 에서는 translate3d 를 지원하므로 css 로 애니메이션이 동작을 하는데, 애니메이션이 끝나면 transitionend 이벤트가 실행이 되고 slider.working = false; 가 되면서 애니메이션이 끝난다.

그런데 스크롤을 함과 동시에 이미지를 넘기면 transitionend 가 실행이 안되고 slider.working 은 계속 ture상태로 남게되면서 bxslider는 더이상 동작하지 않는다.

이 문제를 해결하기 위해서 transitionend 가 발생하지 않으면 slider.working = false; 를 실행시키기 위해 소스를 수정해보았다.

jquery.bxslider.js 를 열어서

var setPositionProperty = function(value, type, duration, params){

이 부분을 찾은다음

// set the property value
el.css(slider.animProp, propValue);

css 속성을 세팅하는 부분 아래에다가

// ios에서 스크롤하면서 작동하면 transitionend 이벤트가 안먹혀서 추가함 by starkey
var dummy = setTimeout(function(){
    slider.working = false;
}, duration+1);
// -->

를 추가하고,

정상적으로 transitionend 가 발생했을대 clearTimeout 을 해준다.

el.bind('transitionend webkitTransitionEnd oTransitionEnd MSTransitionEnd', function(){
   clearTimeout(dummy); // transitionend 가 동작하면 clearTimeout 해줌
   // unbind the callback
   el.unbind('transitionend webkitTransitionEnd oTransitionEnd MSTransitionEnd');
   updateAfterSlideTransition();
});

출처 :

http://starkey1984.blogspot.kr/2016/04/bxslider-ios-freezes.html

2. 주석처리 

var onTouchStart = function(e){
   if(slider.working){

    //e.preventDefault(); //주석하기

...

var onTouchMove = function(e){
   var orig = e.originalEvent;
   // if scrolling on y axis, do not prevent default
   var xMovement = Math.abs(orig.changedTouches[0].pageX - slider.touch.start.x);
   var yMovement = Math.abs(orig.changedTouches[0].pageY - slider.touch.start.y);
   // x axis swipe
   if((xMovement * 3) > yMovement && slider.settings.preventDefaultSwipeX){

    //e.preventDefault(); //주석하기

List of Articles
번호 제목 날짜 조회 수
159 이미지 확대/축소 2020.11.25 972
158 이미지 클릭시 확대하기 file 2016.09.21 12646
157 이미지 클릭 손 (cursor:pointer) 2016.11.18 7118
156 외부 파일 드래그 드롭 구현 file 2018.09.06 1678
155 예제로 만나보는 제이쿼리 - 비동기 파일업로드 file 2017.03.06 7344
154 시간 카운트 2016.12.22 7108
153 슬라이드 쇼 file 2016.09.21 6611
152 스크롤 최하단 자동 포커스(auto scroll to bottom of page with jquery) 2018.11.07 1571
151 속성선택자를 이용해서 링크에 스타일 입히기 2016.09.21 11535
150 셀렉트박스에서 특정 옵션 선택시 레이어 나타내기 2016.12.22 10484
149 새창(자식창) 제어하기, 새창 POST방식으로 값 넘기기 2021.03.26 785
148 사업자 번호를 입력하면 자동으로 하이픈을 붙여줍니다. 2020.08.24 703
147 비활성화 된 라디오버튼 클릭 시 경고창 생성 2018.11.07 1396
146 벨리데이션 체크 / validator / 자동 입력 제한 2016.09.09 7142
145 목록의 체크 선택/해제에 따라 [전체선택] 체크박스를 체크하거나 해제하기 2021.03.25 329
144 모든 링크를 읽어들여 기존의 태그 뒤에 새창열기 태그를 추가하기 예 2021.03.25 183
143 모달 띄우는 코드 2021.03.25 657
142 마우스 좌표 얻기 2021.03.31 271
141 라디오 버튼 선택값 가져오기 2021.03.26 229
140 따욤표 중복으로 출력하기 2018.09.28 1884
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved