data uris
데이타 uri스킴이라 읽는거 같습니다.
이것은 이미지같은 외부 데이터를 uri로 표현 하는 방식입니다보통 <img src='/project/wow.jpg' alt='' /> 와 같이 이미지를 불러들입니다
이 이미지를 불러오는 방식에 대해 의문을 갖고 보신적이 있으신가요?
이렇게 데이터를 저장하고 불러오는 방식뿐이 없을까..
다른 방법이 있습니다
그게 데이타스킴 방식입니다
base64 로 인코딩한 data를 src에 직접 넣는 방식입니다
보통은 절대 또는 상대 경로로 불러옵니다.data file이 있는 경로로 지정하여 불러옵니다
하지만 base64로 인코딩 하여
<img width="111" height="79" title="" alt="" src="" />
이런식으로 넣어도 나옵니다
http://pakss3.realmind.net/datauris.html (여기서 확인 해 보실수 있습니다)
아래 사이트에서 인코딩하여 넣으면 다른 이미지들도 바로 사용 하실 수 있습니다. http://www.websemantics.co.uk/online_tools/image_to_data_uri_convertor/result/
기본적인 포맷:
data:[<mime type>][;charset=<charset>][;base64],<encoded data>
왜 이걸 사용할까?
가장 큰 이유는 HTTP 요청할 이미지 데이터를 저장함으로써 기본적인 document 크기가 다른 요소(이미지 데이터등 )을 불러올때보다 훨씬 빠르게 요소를 가져올 수 있습니다브라우저 호환성
데이터 URI의는 IE 5-7에서 작동하지 않지만, IE 8에서 지원됩니다.- 이미지를 넣기 위해서는 IE 전용 스타일시트(IE-only stylesheet)를 사용하거나,
- noImage처리 후 좀 더 나은 브라우저를 이용하라 한다
- 아니면 대체방법(링크)을 읽어보고 처리하십시요
중요 사항
- 임베디드 코드의 크기 자체에 의한 자원의 크기보다 약간 큽니다. GZip압축이 도움 됩니다.
- Internet Explorer 8은 32,768 바이트의 가장 낮은 최대 데이터 URI 크기를 가지고 있습니다
- 사이트 모든 데이터를 임베디드 data URIs로 유지하긴 힘들다. 단지 이미지 업데이트하는것은 간편해졌다
- PHP(or PHP as CSS), 를 사용한다면 data URIs를 만들기 쉽다 <?php echo base64_encode(file_get_contents("../images/folder16.gif")) ?>
- 용량이 좀 되는 css파일을 캐시하여 사용하면 도움이 된다. css파일이 50kb로 6개가 있다면 300kb의 한번의 문서를 불러들이면 6번의 request를 절약할 수 있다. 그러나 그게 이미지 파일을 캐시 할지 모르겟지만 css파일 만료일 설정을 해주면 도움이 될 것이다.
- Data URIs는 이미지에 국한되지 않습니다.
참고문서 http://jonraasch.com/blog/css-data-uris-in-all-browsers
writer : 오홍홍 // http://pakss3.blogspot.com/
댓글 없음:
댓글 쓰기