> 웹 프론트엔드 > JS 튜토리얼 > 다양한 브라우저에서 JavaScript의 세로 스크롤 비율을 확인하는 방법은 무엇입니까?

다양한 브라우저에서 JavaScript의 세로 스크롤 비율을 확인하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-10-18 17:17:03
원래의
578명이 탐색했습니다.

How to Determine Vertical Scroll Percentage in JavaScript Across Different Browsers?

JavaScript의 세로 스크롤 비율 결정: 브라우저 간 접근 방식

사용자의 세로 스크롤 비율을 결정하는 기능은 스크롤 구현에 매우 중요합니다. 웹 애플리케이션의 종속 기능. 이 포괄적인 가이드는 스크롤된 비율을 정확하게 계산하기 위한 크로스 브라우저 솔루션을 제공합니다.

비 프레임워크 솔루션

Chrome, Firefox 및 IE9와 같은 브라우저의 경우 다음 공식을 사용하여 스크롤 비율을 계산할 수 있습니다.

<code class="javascript">var percent = (h[st]||b[st]) / ((h[sh]||b[sh]) - h.clientHeight) * 100;</code>
로그인 후 복사

여기서:

  • h는 문서의 루트 요소입니다
  • b는 문서의 본문 요소입니다
  • st는 'scrollTop'(WebKit 브라우저의 경우) 또는 'scrollTop'(다른 브라우저의 경우)입니다
  • sh는 'scrollHeight'(WebKit 브라우저의 경우) 또는 'scrollHeight'(다른 브라우저의 경우)입니다. )

함수 구현

재사용을 위해 이 공식을 함수로 캡슐화할 수 있습니다.

<code class="javascript">function getScrollPercent() {
    var h = document.documentElement, 
        b = document.body,
        st = 'scrollTop',
        sh = 'scrollHeight';
    return (h[st]||b[st]) / ((h[sh]||b[sh]) - h.clientHeight) * 100;
}</code>
로그인 후 복사

jQuery Solution

jQuery를 사용하는 경우 다음 코드 조각은 스크롤 비율 계산을 위한 브라우저 간 솔루션을 제공합니다.

<code class="javascript">$(window).on('scroll', function(){
  var s = $(window).scrollTop(),
      d = $(document).height(),
      c = $(window).height();

  var scrollPercent = (s / (d - c)) * 100;
  
  console.clear();
  console.log(scrollPercent);
})</code>
로그인 후 복사

참고

  • 최신 모바일 브라우저의 경우 브라우저 UI 스크롤 시 자동 숨기기 동작으로 인해 솔루션이 100%에 도달하지 못할 수 있습니다.
  • jQuery 솔루션은 제공된 원래 답변을 기반으로 합니다.

위 내용은 다양한 브라우저에서 JavaScript의 세로 스크롤 비율을 확인하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿