>웹 프론트엔드 >CSS 튜토리얼 >jQuery를 사용하여 두 Div 간에 부드럽고 동기화된 스크롤을 구현하는 방법은 무엇입니까?

jQuery를 사용하여 두 Div 간에 부드럽고 동기화된 스크롤을 구현하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-10-25 13:38:02504검색

How to Implement Smooth and Synchronized Scrolling Between Two Divs with jQuery?

부드러운 동기화 스크롤

다음 코드를 사용하면 jQuery를 사용하여 두 DIV 간의 동기화 스크롤을 구현할 수 있습니다.

$(document).ready(function() {
    $("#div1").scroll(function () {
        $("#div2").scrollTop($("#div1").scrollTop());
    });
    $("#div2").scroll(function () {
        $("#div1").scrollTop($("#div2").scrollTop());
    });
});

그러나 이 코드는 두 가지 문제에 직면합니다:

1. 다양한 Div 크기로 인한 비동기 스크롤

비례 스크롤 위치를 계산하려면 스크롤된 콘텐츠의 비율을 결정해야 합니다. 이는 다음을 사용하여 달성할 수 있습니다.

percentage = this.scrollTop / (this.scrollHeight - this.offsetHeight);

다른 div의 높이와 오프셋에 이 백분율을 곱하면 비례 스크롤이 보장됩니다.

2. Firefox의 부드럽지 않은 스크롤

Firefox에서 스크롤 이벤트의 무한 루프를 방지하려면 일시적으로 리스너 바인딩을 해제하는 것이 좋습니다.

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);
    setTimeout(function(){ $other.on('scroll', sync ); }, 10);
}
$divs.on( 'scroll', sync);

이 솔루션은 조정하기 전에 리스너의 연결을 해제합니다. 잠시 지연된 후 scrollTop을 다시 바인딩하고 Firefox에서 원활한 스크롤을 보장합니다.

이 솔루션을 시연하려면 대화형 JSFiddle을 확인하세요: http://jsfiddle.net/b75KZ/5/

위 내용은 jQuery를 사용하여 두 Div 간에 부드럽고 동기화된 스크롤을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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