티스토리 뷰
Base64 이미지 사용하기
pilot376 2013. 7. 12. 10:05Base64가 뭐지??
“Base 64″란 8비트 이진 데이터(예를 들어 실행 파일이나, ZIP 파일 등)를 문자 코드에 영향을 받지 않는 공통 ASCII 문자열로 바꾸는 인코딩 방식을 가리키는 개념이다.
Base64 이미지 사용
이 아이콘을 Base64로 인코딩하면 아래와 같은 문자값을 얻을 수 있다.
(http://www.base64-image.de/)

마크업과 css에서 이미지를 넣을 때 이미지 대신 Base64 문자열을 넣어주면 Base64 이미지를 넣을 수 있다.
/* 이미지태그 */
<img src="이미지.png" alt="" />
<img src="base64 인코딩 문자" alt="" />
/* background */
background:url(이미지.png);
background:url(base64 인코딩 문자);
장점
- 별도 이미지 파일이 필요 없다. 위의 문자열 자체가 이미지이기 때문에 별도 이미지 파일이 없어도 브라우저에서 이미지를 렌더링한다.
- 브라우저가 이미지를 렌더링할 때, 문서 로딩이 끝난 후에 이미지를 렌더링하기 시작하는데 이미지가 깜박이는 화면이 보이거나 네트워크가 좋지 않을 때 이미지가 로딩되지 않는 때도 있다. 만약 base64로 인코딩한 이미지를 사용하면, 문서를 로딩할 때 base64 이미지도 로딩되기 때문에 그런 현상이 사라진다.
단점
- 용량이 커진다. 위의 아이콘을 예로 들면 571바이트짜리 이미지가 인코딩 후에는 777바이트로 용량이 증가하였다. 약 137% 정도 커진다.
- 큰 이미지를 인코딩한 경우 어마어마한 길이의 base64 코드로 인코딩되기 때문에 소스의 가독성이 떨어진다.
- Base64 인코딩 이미지를 많이 사용할 경우, 문서 자체를 로딩하는데 많은 시간이 걸려 자칫 더 느리다는 느낌이 들 수 있다.
관련 포스트
- canvas를 이용하여 base64 이미지 만들기 : https://pilot376.tistory.com/53
- dev tools
- vue.js
- BASE64
- TDD
- javascipt
- 유닛테스트
- JSON.stringify
- ubuntu
- 풋볼매니저 터치 2018
- JSONPlaceholder
- css
- Android
- chrome
- html
- 렌더링 이슈
- JavaScript
- 앱링크
- jekyll
- nginx
- Git
- 파이어폭스
- AWS
- axios-mock-adapter
- Total
- Today
- Yesterday