Front-end/CSS
상하 스크롤 하단 뿌옇게 처리하기
mooyou
2024. 1. 2. 09:06
728x90
300x250
SMALL
하단이 뿌옇게 처리된 상하 스크롤
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
body {
font-family: Arial, sans-serif;
margin: 0;
padding: 0;
height: 100vh; /* body 높이를 전체 뷰포트 높이로 설정 */
overflow: hidden; /* 복수의 스크롤바가 나타나지 않도록 body의 오버플로우 감춤 */
}
#scrollable-list {
height: calc(100% - 50px); /* bottom-blur의 높이를 뺀 부분으로 scrollable-list의 높이 설정 */
overflow-y: auto;
border-bottom: 10px solid rgba(0, 0, 0, 0.1);
position: relative;
}
.list-item {
padding: 10px;
border-bottom: 1px solid rgba(0, 0, 0, 0.1);
cursor: pointer;
}
.list-item a {
text-decoration: none;
color: inherit;
}
#scrollable-list::after {
content: "";
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: 50px;
background: linear-gradient(to top, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
z-index: 1;
}
</style>
</head>
<body>
<div id="scrollable-list">
<div class="list-item"><a href="#">리스트 아이템 1</a></div>
<div class="list-item"><a href="#">리스트 아이템 2</a></div>
<div class="list-item"><a href="#">리스트 아이템 3</a></div>
<div class="list-item"><a href="#">리스트 아이템 4</a></div>
<div class="list-item"><a href="#">리스트 아이템 5</a></div>
<div class="list-item"><a href="#">리스트 아이템 6</a></div>
<div class="list-item"><a href="#">리스트 아이템 7</a></div>
</div>
</body>
</html>
#scrollable-list::after 가상 요소를 사용해서 하단 뿌옇게 처리된 배경을 만들었다.
그런데 여기서 문제는 맨마지막 리스트가 가상 요소 영역에 가려서 클릭이 안된다는 것이다.
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
body {
font-family: Arial, sans-serif;
margin: 0;
padding: 0;
height: 100vh; /* body 높이를 전체 뷰포트 높이로 설정 */
overflow: hidden; /* 복수의 스크롤바가 나타나지 않도록 body의 오버플로우 감춤 */
}
#scrollable-list {
height: calc(100% - 50px); /* bottom-blur의 높이를 뺀 부분으로 scrollable-list의 높이 설정 */
overflow-y: auto;
border-bottom: 10px solid rgba(0, 0, 0, 0.1);
position: relative;
}
.list-item {
padding: 10px;
border-bottom: 1px solid rgba(0, 0, 0, 0.1);
cursor: pointer;
}
.list-item a {
text-decoration: none;
color: inherit;
}
#scrollable-list::after {
content: "";
position: absolute;
bottom: 0;
left: 0;
width: 100%;
height: 50px;
background: linear-gradient(to top, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
z-index: 1;
pointer-events: none; /* 마우스 이벤트를 가로막지 않도록 함 */
}
</style>
</head>
<body>
<div id="scrollable-list">
<div class="list-item"><a href="#">리스트 아이템 1</a></div>
<div class="list-item"><a href="#">리스트 아이템 2</a></div>
<div class="list-item"><a href="#">리스트 아이템 3</a></div>
<div class="list-item"><a href="#">리스트 아이템 4</a></div>
<div class="list-item"><a href="#">리스트 아이템 5</a></div>
<div class="list-item"><a href="#">리스트 아이템 6</a></div>
<div class="list-item"><a href="#">리스트 아이템 7</a></div>
</div>
</body>
</html>
pointer-events: none; 해당 요소에 마우스 이벤트를 비활성화하는 스타일을 가상요소에 적용하면 해당 가상 요소 위에서 마우스 이벤트가 발생하지 않아 마우스 클릭 등의 이벤트가 아래의 실제 리스트 아이템에 전달될 수 있게 된다.
pointer-events: none; 이벤트를 적용하지 않으면 해당 가상 요소가 마우스 이벤트를 캡처해서 실제 리스트 아이템을 가리게 된다. 그러나 pointer-events: none;를 적용하면 가상 요소는 마우스 이벤트를 캡처하지 않게 되고 실제 리스트 아이템에 마우스 클릭 등의 이벤트가 전달될수 있게 된다.
728x90
반응형
LIST