> 웹 프론트엔드 > CSS 튜토리얼 > 웹 개발에서 스크롤바를 숨기지 않고 비활성화하려면 어떻게 해야 합니까?

웹 개발에서 스크롤바를 숨기지 않고 비활성화하려면 어떻게 해야 합니까?

Linda Hamilton
풀어 주다: 2024-12-03 09:24:10
원래의
725명이 탐색했습니다.

How Can I Disable Scrollbars Without Hiding Them in Web Development?

숨기지 않고 스크롤바 비활성화

웹 개발에서는 라이트박스를 사용하는 동안 상위 요소의 스크롤바를 비활성화해야 하는 경우가 있습니다. 그러나 Overflow: Hidden을 사용하여 단순히 스크롤 막대를 숨기는 것은 사이트가 점프하여 스크롤 막대가 있던 공간을 차지할 수 있기 때문에 바람직하지 않은 경우가 많습니다.

계속 표시하는 동안 스크롤 막대를 비활성화할 수 있는 실행 가능한 솔루션이 있습니다. 그들을. 라이트박스 아래의 페이지를 상단에 배치할 수 있는 경우 다음 CSS 코드를 활용할 수 있습니다.

body {
  position: fixed;
  overflow-y: scroll;
}
로그인 후 복사

이렇게 하면 스크롤 막대가 표시되지만 콘텐츠가 스크롤되지는 않습니다. 라이트박스를 닫은 후 스크롤바를 복원하려면 다음 속성을 되돌리기만 하면 됩니다.

body {
  position: static;
  overflow-y: auto;
}
로그인 후 복사

이 접근 방식은 스크롤 이벤트를 수정할 필요가 없습니다.

기존 스크롤 위치 해결

라이트박스가 열리기 전에 페이지가 이미 스크롤된 경우 JavaScript를 통해 현재 스크롤 위치를 검색하고 할당할 수 있습니다. 이는 body 요소의 최상위 속성입니다. 이렇게 하면 라이트박스 사용 중에 현재 스크롤 위치가 유지됩니다.

CSS

.noscroll {
  position: fixed; 
  top: var(--st, 0);
  inline-size: 100%;
  overflow-y:scroll; 
}
로그인 후 복사

JavaScript

const b = document.body;
b.style.setProperty('--st', -(document.documentElement.scrollTop) + "px");
b.classList.add('noscroll');
로그인 후 복사

By 이 솔루션을 구현하면 스크롤바를 숨기지 않고 효과적으로 비활성화하여 의도한 시각적 표현을 유지할 수 있습니다. 웹페이지.

위 내용은 웹 개발에서 스크롤바를 숨기지 않고 비활성화하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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