Data URI详细介绍

1、URI介绍

URI(统一资源标识符) 是 uniform resource identifier的缩写,它定义了接受内容的协议以及附带的相关内容,若是附带的相关内容是一个地址,那么此时的 URI 也是一个 URL (uniform resource locator )。javascript

2、什么是 data URI scheme?

Data URI scheme 简称 Data URI,常常会被错误地写成 data URLs。即前缀为data:协议的的URL,其容许内容建立者向文档中嵌入小文件。php

假设咱们有一个图片须要显示在网页上css

一、一般咱们会使用http连接,这种取得资料的方法称为 http URI schemehtml

// 从外部请求一张图片 <img src="http://pic1.win4000.com/wallpaper/c/53cdd1f7c1f21.jpg" alt="">复制代码

二、使用 data URI scheme 获取资料能够写成:html5

// 在HTML中嵌入一个小红点的图片 <img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="">复制代码

经过data RUI scheme,咱们把图像内容内置在HTML 中,节省了一个 HTTP 请求。java

3、Data URI scheme 的语法

data:①[<mime type>]②[;charset=<charset>]③[;<encoding>]④,<encoded data>⑤web

【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=<charset>](可选项): 源文本的字符集编码方式,默认编码是 charset=US-ASCII, 即数据部分的每一个字符都会自动编码为 %xxbash

【4】第④部分 [;<encoding>] : 数据编码方式(默认US-ASCII,BASE64两种)

【5】第⑤部分 ,<encoded data> 编码后的数据

4、Data URI scheme 的利弊

利:

  • 减小 HTTP 请求
  • 当访问外部资源很麻烦或受限时(好比服务器 ip 被墙)
  • 当图片是在服务器端用程序动态生成,每一个访问用户显示的都不一样时
  • 当图片的体积过小,占用一个 HTTP 会话不值得时
  • 没有图片更新要从新上传,还要清理缓存的问题

弊:

  • Base64 编码的数据体积一般是原数据的体积 4/3,也就是 Data URL 形式的图片会比二进制格式的图片体积大 1/3
  • Data URL 形式的图片不会被浏览器缓存,这意味着每次访问页面时都被下载一次。
  • 增长了 CSS 文件的尺寸
  • IE678兼容性
  • 不适合 lazy loading
  • 不利于维护
  • 移动端不宜使用 Data URI 技术(解码耗 CPU)

5、Data URI scheme 的应用实例

【1】在Html的Img对象中使用

<img src="data:image/x-icon;base64,AAABAAEAEBAAAAAAAABoBQAAF..." />复制代码

【2】在Css的background-image属性中使用

div.image {
    width:100px;
    height:100px;
    background-image:url(data:image/x-icon;base64,AAABAAEAEBAAAAAAAABoBQAAF...);
}复制代码

【3】在Html的css连接处使用

<link rel="stylesheet" type="text/css" href="data:text/css;base64,LyogKioqKiogVGVtcGxhdGUgKioq..." />复制代码

【4】在Html的javaScript连接处使用

<script src="data:text/javascript;base64,LyogKioqKiogVGVtcGxhdGUgKioq..." type="text/javascript"></script>复制代码

【5】data RUI scheme也能够直接在浏览器的地址栏中输入进行访问

在浏览器中输入如下的Url,会获得一个加粗的"Hello, world!"。也就是说,data:后面的数据直接用作网页的内容,而不是网页的地址。

data:text/html,<html><body><p><b>Hello, world!</b></p></body></html>复制代码

下面的例子会显示出 "你好,中文!"。

data:text/plain;charset=UTF-8;base64,5L2g5aW977yM5Lit5paH77yB复制代码

6、兼容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("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==");
  *background-image: url(mhtml:http://example.com/test.css!myidBackground); 
}复制代码

上面注释的部分就是一个附件, 这个附件的内容是一个名为myidBackground的Base64编码图片,而后在class为myid的css中使用。

注意:一、boundary字段值可自定义;

二、附件的末行必须为boundary字段值;

三、附件内容不能被压缩工具擦写掉;

四、因为高版本的IE在使用IE8兼容模式时能认识*这个css hack符号,但却不支持mhtml,因此会致使背景图片失效。应该采用IE的条件注释更为稳妥。

7、base64转换工具

Encode Data URL

aTool在线工具

Duri.me

DATAURL

相关文章
相关标签/搜索