본문 바로가기
카테고리 없음

마우스 커서 css로 변경시 Base64를 사용하기

by cariño 2024. 12. 6.
728x90
반응형

자바스크립트로 특정 위치에서 오른쪽 마우스가 눌렸을 때 마우스 모양을 변경을 하는 기능이 추가되었다. 

클래스를 추가했고, 기능은 제대로 동작이 되는데 마우스 모양이 계속 변경이 되지 않는 이슈가 있었다. 

경로도 분명 잘 되었고 개발자도구에서도 이미지는 보이는데 왜 커서가 변경되지않았다.

찾아보니 브라우저가 읽어올때 캐싱이나 로드 실패의 경우도 있을거라는 추측이다. 

 

방법은 base64 형식으로 이미지를 변경해서 즉시 변경 할 수 있게 하는 방법이다. 

 

.custom-cursor {
	cursor: url('https://example.com/cursor.png'), auto;    
}

해당 방법으론 변경이 되지 않았고 

.custom-cursor {
     cursor: url(''),auto;
}

이처럼 Base64 형태로 인코딩해서 사용했더니 잘 출력이 되었다.

 

data:image/png;base64 형식이 보이는 이유는 무엇일까?

결론 부터 말하자면 브라우저는 Base64 데이터를 직접 처리하기 때문이다. 

data:image/png;base64 형식은 데이터 URL이라고 하며, 이미지를 문자열로 인코딩하여 CSS 속성에 직접 포함하는 방법이다.

 

 

어떻게 해서 보이게 되는 것일까?

  1. 브라우저는 데이터 URL을 로컬 리소스처럼 즉시 처리를 한다.
  2. 네트워크 요청이 필요하지 않기 때문에 접근성 문제가 없다.
  3. 형식이 명확하게 지정되기 때문에 브라우저가 이를 바로 렌더링 할 수 있게 된다.

 

data:image/png;base64의 구조 ( 데이터 URL의 기본 구조 )

 

  • data:: 데이터 URL을 나타냄.
  • <MIME-type>: 데이터 형식 (예: image/png, image/svg+xml).
  • ;base64: 데이터가 Base64로 인코딩되었음을 나타냄.
  • <data>: Base64로 인코딩된 실제 데이터.

 

그렇다면 base64형식으로 변환하는 방법은?

1. 온라인 변환 도구를 사용한다. 내가 가진 이미지를 업로드 하고 변환된 문자열을 복사해서 사용하면 된다.

2. 자바스크립트에서 직접 변환이 가능하다. 

 

function convertToBase64(file) {
    const reader = new FileReader();
    reader.onload = function (event) {
        console.log(event.target.result); // Base64 문자열
    };
    reader.readAsDataURL(file);
}

// 사용 예제
const fileInput = document.querySelector('input[type="file"]');
fileInput.addEventListener('change', (event) => {
    const file = event.target.files[0];
    convertToBase64(file);
});

 

 


위에서 언급했듯 브라우저가 리소스를 읽어올 때 로드에 실패를 할 수도 있다. 

base64형태를 사용하면 브라우저가 base64데이터를 직접 처리할 수 있기 때문에 오류를 방지 할 수 있게 된다. 

728x90

댓글