메뉴 건너뛰기

2016.12.22 20:25

bxslider 멈춤현상

조회 수 10115 추천 수 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
번호 제목 날짜 조회 수
59 document.getElementById() 처럼 DOM 객체 얻기 2016.09.21 6810
58 jquery enter key event submit (jquery 엔터키 이벤트) 2016.11.17 6857
57 jQuery Cookie 2016.09.21 6864
56 항상 레이어가 정 가운데 위치하는 스크립트 2016.12.22 6908
55 jQuery Selector (셀렉터) 2016.11.18 6931
54 jQuery Quick API file 2016.09.13 6934
53 jQuery, JavaScript 새로고침(reload) 2016.11.17 6951
52 jquery function 생성 2016.09.11 6963
51 시간 카운트 2016.12.22 7108
50 이미지 클릭 손 (cursor:pointer) 2016.11.18 7118
49 html 테이블 고정 (table fixed) 2016.11.18 7118
48 getScript() 2016.09.21 7125
47 벨리데이션 체크 / validator / 자동 입력 제한 2016.09.09 7142
46 화면 이동시에 레이어가 따라다니게 하기 2016.09.21 7143
45 jquery 라디오버튼 선택 확인, 체크박스 선택 확인, 셀렉트박스 선택 확인 2016.11.17 7149
44 [jQuery Plugin] FCKeditor 2.6.5 사용법 2016.09.11 7179
43 zeroclipboard - 클립보드 복사하기(자바스크립트 클립보드 복사하기) 2016.10.06 7181
42 간단한 세로 메뉴 file 2016.09.21 7306
41 날짜 검색 범위 정하기 (jquery) file 2016.11.17 7320
40 예제로 만나보는 제이쿼리 - 비동기 파일업로드 file 2017.03.06 7344
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved