이번에는 JS를 사용하여 현재 페이지에 스크롤 막대가 있는지 확인하는 방법을 보여 드리겠습니다. JS를 사용하여 현재 페이지에 스크롤 막대가 있는지 확인하는 주의 사항은 무엇입니까? 봐.
서문
최근 플러그인을 작성하는 과정에서 스크롤바가 있는지 확인하기 위해 JS를 사용해야 하는데, 검색 후 일반적인 방법은 비슷하지만 모두 조금 장황하고, 코드가 충분히 간결하지 않습니다. 마지막으로 다양한 방법을 참고하여 비교적 간단한 방법을 작성하였습니다. 스크롤바를 판단할 때 스크롤바의 너비도 계산해야 합니다. 이 글을 통해 공유하겠습니다.
스크롤 막대를 판단해야 하는 이유
스크롤 막대를 판단해야 하는 필요성은 팝업 창 플러그인에서 자주 사용됩니다. 대부분의 팝업 창에는 <a href="%EA%B0%80" target="_blank">overflow<code><a href="//m.sbmmt.com/wiki/923.html" target="_blank">overflow</a>: hidden
的属性,如果页面比较长的话,添加这个属性之后页面会有晃动。
为了增强用户体验,通过判断是否有滚动条而添加 <a href="//m.sbmmt.com/wiki/937.html" target="_blank">margin-left</a>
属性以抵消 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
: 숨겨진 속성입니다. 페이지가 비교적 긴 경우 이 속성을 추가하면 페이지가 흔들립니다.
사용자 경험을 향상하려면 <a href="//m.sbmmt.com/wiki/937.html" target="_blank">margin-left</a>
overflow: hide
이후 스크롤 막대 위치를 오프셋합니다.
스크롤바가 있는지 확인하는 방법
실제로 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
를 사용합니다. > window .innerHeight
를 판단할 수 있습니다. 그러나 IE7 및 IE8에서는 window.innerHeight
가 underfined
되어 있으므로 IE7 및 IE8과 호환되려면 document.documentElement를 사용해야 합니다. .clientHeight
속성 창 높이를 계산합니다.
스크롤바 너비를 계산하는 방법
offsetWidth
와 clientWidth
의 차이로 얻을 수 있습니다. >Magnific-popup은 여기입니다. 코드의 메소드>🎜rrreee🎜🎜🎜이 기사의 사례를 읽은 후 메소드를 마스터했다고 생각합니다. 더 흥미로운 정보를 보려면 PHP의 다른 관련 기사에 주목하세요. 중국사이트! 🎜🎜추천 도서: 🎜🎜🎜Ajax()와 배경 간의 상호 작용 단계에 대한 자세한 설명🎜🎜🎜🎜🎜Django에서 Ajax를 사용하는 방법🎜🎜🎜위 내용은 JS를 사용하여 현재 페이지에 스크롤 막대가 있는지 확인하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!