
1. 서론
오늘은 웹사이트에서 마우스 커서를 JavaScript와 CSS를 이용해 바꾸는 방법에 대해 자세히 알아보겠습니다.
웹사이트를 더 감각적으로 만들고 싶거나, 게임/이벤트 페이지 등에서 사용자 경험을 향상시키고 싶으신가요?
그렇다면 커서를 커스터마이징하는 방법이 큰 도움이 될 수 있습니다.
기본적인 커서 변경부터, 이미지 커서를 직접 따라다니는 고급 방식까지 예제를 중심으로 소개해드릴게요.
2. CSS로 커서 바꾸기 (가장 간단한 방법)
2.1. 기본 커서 스타일 적용
CSS만으로도 커서를 쉽게 변경할 수 있습니다.
* {
cursor: pointer; /* 또는 crosshair, move 등 기본 커서 종류 */
}
2.2. 이미지 커서 적용하기
커스텀 이미지를 사용할 수도 있어요.
* {
cursor: url(''), auto;
}
주의사항: 이미지는.png
등의 파일 확장자 형태로 넣으면 안 되고 data:
로 시작하는 svg
코드를 삽입해야 적용됩니다.
커서 이미지를 SVG로 커스터마이징하고 싶으시다면,
아래 포스팅을 참고해주세요!
👉 SVG 아이콘 삽입 3가지 방법 (웹사이트에 유연하게 적용하는 법)
2.3. 이미지 커서 적용하기
.cur
확장자 파일을 적용할 수도 있습니다.
* {
cursor: url('cursor-image.png'), auto;
}
2.4. 자주 사용되는 기본 커서 스타일
커서 값 | 설명 |
---|---|
default | 기본 화살표 커서 |
pointer | 클릭 가능한 요소 (ex. 버튼) |
text | 텍스트 입력 영역 |
move | 드래그 또는 이동 가능한 요소 |
not-allowed | 금지 또는 비활성화 상태 표시 |
wait | 로딩 중 상태 표시 (모래시계 등) |
grab / grabbing | 드래그 인터랙션에서 자주 사용됨 |
3. JavaScript로 커서 바꾸기
JS를 이용하면 특정 상황에 따라 커서를 바꾸는 동적 처리도 가능합니다.
document.body.style.cursor = "grab"; // 전체 페이지 커서 변경
특정 요소에 마우스를 올렸을 때만 커서를 변경할 수도 있어요.
const el = document.getElementById("target");
el.addEventListener("mouseenter", () => {
el.style.cursor = "zoom-in";
});
el.addEventListener("mouseleave", () => {
el.style.cursor = "default";
});
4. 완전 커스텀 커서 만들기 (JS + CSS 조합)
기본 커서가 아닌, 이미지나 요소가 마우스를 따라다니는 형태로 커서를 완전히 커스터마이징할 수도 있어요.
<style>
body {
cursor: none; /* 기존 커서 숨기기 */
}
.custom-cursor {
position: fixed;
width: 24px;
height: 24px;
background: url('cursor.png') no-repeat center center;
background-size: cover;
pointer-events: none;
z-index: 9999;
}
</style>
<div class="custom-cursor" id="cursor"></div>
<script>
const cursor = document.getElementById("cursor");
document.addEventListener("mousemove", (e) => {
cursor.style.transform = `translate(${e.clientX}px, ${e.clientY}px)`;
});
</script>
이 방식은 특히 디자인 포트폴리오, 게임, 캠페인 페이지에서 많이 사용됩니다.pointer-events: none
은 커서 이미지가 클릭 이벤트를 막지 않도록 하기 위해 필수예요.
5. 커서 이미지 사용 시 브라우저 호환성 주의사항
.png
외에.cur
,.ani
포맷도 일부 브라우저에서 지원됩니다.- 크롬은
32x32px
이하의 커서 이미지를 권장하며, 너무 큰 이미지는 자동 축소되거나 동작하지 않을 수 있습니다. - 모바일 브라우저는
cursor
속성의 지원이 제한적이므로, 모바일 환경은 기본 커서를 유지하거나 대응을 고려해야 합니다.
6. 고급 팁: 반응형 웹에서의 커서 처리
웹사이트가 반응형이라면, 마우스 커서가 적용되지 않는 모바일/터치 환경도 고려해야 합니다.
@media (hover: hover) and (pointer: fine) {
body {
cursor: url('cursor.png'), auto;
}
}
이렇게 설정하면, 터치 디바이스에서는 커서 변경이 적용되지 않고, 데스크탑 환경에서만 작동하도록 할 수 있어요.
7. 자주 묻는 질문 (FAQ)
Q1. 마우스 커서를 특정 버튼에만 적용할 수 있나요?
네. CSS나 JS로 해당 요소에만 cursor
속성을 지정하면 됩니다.
Q2. 이미지 커서가 적용되지 않아요!
이미지 경로를 확인하고, PNG 형식과 크기를 다시 체크해주세요.
또한, HTTPS 환경에서 http://
이미지 경로는 차단될 수 있으니 주의하세요.
Q3. 모바일에서도 적용되나요?
대부분 모바일 브라우저는 커서 스타일을 지원하지 않기 때문에, 데스크탑 전용 기능으로 간주하는 것이 좋습니다.
8. 참고 자료
- MDN Docs: CSS cursor 속성
- 커스텀 커서 예제: CodePen 예제 보기