一、URI介绍
URI(统一资源标识符) 是 uniform resource identifier的缩写,它定义了接受内容的协议以及附带的相关内容,如果附带的相关内容是一个地址,那么此时的 URI 也是一个 URL (uniform resource locator)。
二、什么是 data URI scheme?
Data URI scheme 简称 Data URI,经常会被错误地写成 data URLs。即前缀为data:协议的的URL,其允许内容创建者向文档中嵌入小文件。
假设我们有一个图片需要显示在网页上
1、通常我们会使用http链接,这种取得资料的方法称为 http URI scheme:
// 从外部请求一张图片
2、使用 data URI scheme 获取资料可以写成:
// 在HTML中嵌入一个小红点的图片
通过data RUI scheme,我们把图像内容内置在HTML 中,节省了一个 HTTP 请求。
三、Data URI scheme 的语法
data:①[
]②[;charset= ]③[; ]④, ⑤
【1】第①部分data: 协议头,它标识这个内容为一个 data URI 资源。
【2】第②部分MIME 类型(可选项):浏览器通常使用MIME类型(而不是文件扩展名)来确定如何处理文档;因此服务器设置正确以将正确的MIME类型附加到响应对象的头部是非常重要的。MIME类型对大小写不敏感,但是传统写法都是小写。
| 类型 | 描述 | 示例(语法:type/subtype 类型/子类型****) |
| text | 表明文件是普通文件,理论上是人类可读的 | text/plain,text/html,text/css,text/javascript |
| image | 表明文件某种是图像文件,gif动态图也属于image类型 | image/gif,image/png,image/jpeg,image/bmp,image/webp,image/x-icon,image/vnd.microsoft.icon |
| audio | 表明文件是某种音频文件 | audio/midi,audio/mpeg,audio/webm,audio/ogg,audio/wav |
| video | 表明文件是某种视频文件 | video/webm,video/ogg |
| application | 表明文件是某种二进制数据 | application/octet-stream,application/pkcs12,application/vnd.mspowerpoint,application/xhtml+xml,application/xml,application/pdf |
【3】第③部分 ;charset=
【4】第④部分 [;
【5】第⑤部分 ,
四、Data URI scheme 的利弊
利:
- 减少 HTTP 请求
- 当访问外部资源很麻烦或受限时(比如服务器 ip 被墙)
- 当图片是在服务器端用程序动态生成,每个访问用户显示的都不同时
- 当图片的体积太小,占用一个 HTTP 会话不值得时
- 没有图片更新要重新上传,还要清理缓存的问题
弊:
- Base64 编码的数据体积通常是原数据的体积 4/3,也就是 Data URL 形式的图片会比二进制格式的图片体积大 1/3
- Data URL 形式的图片不会被浏览器缓存,这意味着每次访问页面时都被下载一次。
- 增加了 CSS 文件的尺寸
- IE678兼容性
- 不适合 lazy loading
- 不利于维护
- 移动端不宜使用 Data URI 技术(解码耗 CPU)
五、Data URI scheme 的应用实例
【1】在Html的Img对象中使用
【2】在Css的background-image属性中使用
div.image {
width:100px;
height:100px;
background-image:url(...);
}
【3】在Html的css链接处使用
【4】在Html的javaScript链接处使用
**【5】data RUI scheme也可以直接在浏览器的地址栏中输入进行访问 **
①在浏览器中输入以下的Url,会得到一个加粗的"Hello, world!"。也就是说,data:后面的数据直接用做网页的内容,而不是网页的地址。
data:text/html,Hello, world!
②下面的例子会显示出 "你好,中文!"。
data:text/plain;charset=UTF-8;base64,5L2g5aW977yM5Lit5paH77yB
六、兼容IE678 - MHTML
MHTML 即 MIME HTML(Multipurpose Internet Mail Extensions HyperText Markup Language),就是将Data URI以附件的形式附加到页面页面上,具体示例如下:
/** FilePath: http://example.com/test.css */
/*!@ignore
Content-Type: multipart/related; boundary="_ANY_SEPARATOR"
--_ANY_SEPARATOR
Content-Location:myidBackground
Content-Transfer-Encoding:base64
iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==
--_ANY_SEPARATOR--
*/
.myid {
background-image: url("");
*background-image: url(mhtml:http://example.com/test.css!myidBackground);
}
上面注释的部分就是一个附件, 这个附件的内容是一个名为myidBackground的Base64编码图片,然后在class为myid的css中使用。
注意:1、boundary字段值可自定义;
2、附件的末行必须为boundary字段值;
3、附件内容不能被压缩工具擦写掉;
4、由于高版本的IE在使用IE8兼容模式时能认识*这个css hack符号,但却不支持mhtml,所以会导致背景图片失效。应该采用IE的条件注释更为稳妥。
七、base64转换工具
Encode Data URL
aTool在线工具
Duri.me
DATAURL