>  기사  >  웹 프론트엔드  >  JS를 통해 페이지에 스크롤 막대가 있는지 확인하는 방법

JS를 통해 페이지에 스크롤 막대가 있는지 확인하는 방법

亚连
亚连원래의
2018-05-26 14:53:191422검색

최근 플러그인을 작성하는 과정에서 스크롤 바가 있는지 확인하기 위해 JS를 사용해야 하는데, 검색 후 일반적인 방법은 비슷하지만 조금 장황하고 코드가 간결하지 않습니다. 마지막으로 여러가지 방법을 참고해서 비교적 간단한 방법을 작성했습니다

Preface

최근 플러그인을 작성하는 과정에서 스크롤바가 있는지 확인하기 위해 JS를 사용하게 됐는데요. 일반적인 방법은 비슷하지만 모두 약간 장황하고 코드가 간결하지 않습니다. 마지막으로 다양한 방법을 참고하여 비교적 간단한 방법을 작성하였습니다. 스크롤바를 판단할 때 스크롤바의 너비도 계산해야 합니다. 이 글을 통해 공유하겠습니다.

스크롤 막대를 판단해야 하는 이유

스크롤 막대를 판단해야 하는 필요성은 팝업 창 플러그인에서 자주 사용됩니다. 왜냐하면 대부분의 팝업 창에는 overflow:hidden이 추가되기 때문입니다. 속성, 페이지가 상대적으로 긴 경우 이 속성을 추가하면 페이지가 흔들립니다. overflow: hidden 的属性,如果页面比较长的话,添加这个属性之后页面会有晃动。

为了增强用户体验,通过判断是否有滚动条而添加 margin-left 属性以抵消 overflow: hidden 之后的滚动条位置。

判断是否有滚动条的方法

其实只需要一行 JS 就可以,测试兼容 IE7

function hasScrollbar() {
  return document.body.scrollHeight > (window.innerHeight || document.documentElement.clientHeight);
}

一般情况下,使用 document.body.scrollHeight > window.innerHeight 就可以判断。

但是在 IE7,IE8 中 window.innerHeight 为 underfined,所以为了兼容 IE7、IE8,需要使用document.documentElement.clientHeight 属性计算窗口高度。

计算滚动条宽度的方法

还是以弹窗为例,因为 IE 10 以上以及移动端浏览器的滚动条都是不占据页面宽度的透明样式(其中 IE 10 以上浏览器可以通过 CSS 属性还原原始的滚动条样式),所以为了进一步增强用户体验,我们还需要计算滚动条的宽度,根据情况添加合理的 margin-left 数值。

计算滚动条宽度的方法比较简单,新建一个带有滚动条的 p 元素,通过该元素的 offsetWidth clientWidth 的差值即可获得,我在此借鉴 Magnific-popup

사용자 경험을 향상하려면 스크롤 막대가 있는지 확인하여 overflow:hidden 이후 스크롤 막대의 위치를 ​​오프셋하는 margin-left 속성을 ​​추가하세요. .

스크롤 막대가 있는지 확인하는 방법

실제로 JS 한 줄만 필요합니다. 테스트는 IE7

function getScrollbarWidth() {

  var scrollp = document.createElement("p");
  scrollp.style.cssText = 'width: 99px; height: 99px; overflow: scroll; position: absolute; top: -9999px;';
  document.body.appendChild(scrollp);
  var scrollbarWidth = scrollp.offsetWidth - scrollp.clientWidth;
  document.body.removeChild(scrollp);

  return scrollbarWidth;

}

일반적으로 document.body.scrollHeight > <code>window.innerHeight 를 판단할 수 있습니다.

그러나 IE7 및 IE8에서는 window.innerHeightunderfined되어 있으므로 IE7 및 IE8과 호환되려면 document.documentElement를 사용해야 합니다. .clientHeight 속성 창 높이를 계산합니다.
스크롤바 너비를 계산하는 방법

은 여전히 ​​팝업창을 예로 들고 있는데, IE 10 이상과 모바일 브라우저의 스크롤바는 페이지를 차지하지 않는 투명한 스타일이기 때문입니다. 너비(IE 10 이상 브라우저는 CSS 속성을 사용하여 원래 스크롤 막대 스타일을 복원할 수 있음)이므로 사용자 경험을 더욱 향상하려면 스크롤 막대의 너비를 계산하고 합리적인 를 추가해야 합니다. 상황에 따라 margin-left 값을 조정합니다.

스크롤 너비 계산 방법 bar는 상대적으로 간단합니다. 스크롤 막대가 있는 새 p 요소를 생성합니다. 이는 요소의 offsetWidthclientWidth의 차이로 얻을 수 있습니다. >Magnific-popup 코드의 메소드>

rrreee🎜🎜🎜위 내용은 앞으로 모든 사람에게 도움이 되기를 바랍니다. 🎜🎜관련 기사: 🎜🎜🎜h5 기록을 기반으로 ajax 목록 요청 경험 개선🎜🎜🎜🎜🎜AJAX 핵심 개체에 대해 간략하게 설명🎜🎜🎜🎜🎜Ajax 데이터 전송 방법의 자세한 예🎜🎜🎜🎜🎜 🎜🎜

위 내용은 JS를 통해 페이지에 스크롤 막대가 있는지 확인하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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