본문 바로가기
Tech/CSS

웹사이트 마우스 커서 바꾸기 커스터마이징 - CSS와 JavaScript 방법 총정리 (Custom Cursor Tips)

by newstar_ 2025. 4. 11.

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. 참고 자료