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 속성에 직접 포함하는 방법이다.
어떻게 해서 보이게 되는 것일까?
- 브라우저는 데이터 URL을 로컬 리소스처럼 즉시 처리를 한다.
- 네트워크 요청이 필요하지 않기 때문에 접근성 문제가 없다.
- 형식이 명확하게 지정되기 때문에 브라우저가 이를 바로 렌더링 할 수 있게 된다.
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
댓글