>웹 프론트엔드 >CSS 튜토리얼 >jQuery에서 부드럽고 비례적인 동기화 스크롤을 달성하는 방법: Firefox 지연 문제에 대한 해결책?

jQuery에서 부드럽고 비례적인 동기화 스크롤을 달성하는 방법: Firefox 지연 문제에 대한 해결책?

Patricia Arquette
Patricia Arquette원래의
2024-10-25 08:26:02715검색

How to Achieve Smooth and Proportional Synchronized Scrolling in jQuery: A Solution to the Firefox Lag Issue?

jQuery의 동기화된 스크롤링 딜레마: 부드럽고 비례적인 스크롤링 달성

동기화된 스크롤링을 구현하는 것은 다양한 크기의 요소를 처리할 때 어려울 수 있습니다. 이 문제를 해결하려면 스크롤된 콘텐츠의 비율을 확인하고 다른 요소에 해당하는 scrollTop 값을 계산해야 합니다.

귀하의 경우에는 scrollTop / (scrollHeight - offsetHeight) 공식을 사용할 수 있습니다. 이는 스크롤된 요소의 백분율을 나타내는 0에서 1 사이의 값을 산출합니다.

또한 Firefox에서 스크롤이 느려지는 문제가 발생할 수 있습니다. 이는 현재 코드가 실수로 스크롤 이벤트의 끊임없는 루프를 생성한다는 사실에서 비롯됩니다. off()를 사용하여 리스너를 일시적으로 바인딩 해제하고, scrollTop을 조정한 다음 다시 바인딩하면 이 문제를 해결할 수 있습니다.

다음은 두 문제를 모두 해결하는 최적화된 코드 조각입니다.

var $divs = $('#div1, #div2');

var sync = function(e){
    var $other = $divs.not(this).off('scroll'), other = $other.get(0);
    var percentage = this.scrollTop / (this.scrollHeight - this.offsetHeight);
    other.scrollTop = percentage * (other.scrollHeight - other.offsetHeight);
    
    // Firefox workaround: Rebinding without delay is insufficient.
    setTimeout( function(){ $other.on('scroll', sync ); },10);
}

$divs.on( 'scroll', sync);

이 코드 Firefox에서 스크롤 이벤트의 무한 루프를 방지하면서 비례 스크롤을 보장합니다. 작동 데모를 보려면 jsfiddle을 방문하세요. http://jsfiddle.net/b75KZ/5/

위 내용은 jQuery에서 부드럽고 비례적인 동기화 스크롤을 달성하는 방법: Firefox 지연 문제에 대한 해결책?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.