최근 플러그인을 작성하는 과정에서 스크롤 바가 있는지 확인하기 위해 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 한 줄만 필요합니다. 테스트는 IE7function 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.innerHeight
가 underfined
되어 있으므로 IE7 및 IE8과 호환되려면 document.documentElement를 사용해야 합니다. .clientHeight
속성 창 높이를 계산합니다.
스크롤바 너비를 계산하는 방법
스크롤 너비 계산 방법 bar는 상대적으로 간단합니다. 스크롤 막대가 있는 새 p 요소를 생성합니다. 이는 요소의 offsetWidth
와 clientWidth
의 차이로 얻을 수 있습니다. >Magnific-popup 코드의 메소드>
위 내용은 JS를 통해 페이지에 스크롤 막대가 있는지 확인하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!