当前位置: 代码迷 >> 综合 >> data URI scheme
  详细解决方案

data URI scheme

热度:51   发布时间:2023-11-25 14:08:44.0

data URI scheme(数据URI方案)是URI(统一资源标识符)方案,它提供了一种在网页中内联包含数据的方式,这些数据好像它们是外部资源一样。它目的是将一些小的数据,直接嵌入到网页中,这样就不用再从外部文件载入。常常用于把图片嵌入网页中。

语法

data:[<media type>][;base64],<data>

data代表方案名称,后跟:
<media type> 为可选的以部分,这部分表示媒体类型,可以有一个或多个参数,不同参数之间用;分隔。参数的格式为attribute=value。比如我们可以指定编码的字符集charset;数据的MIME 类型;以及编码格式。也就是这种格式

data:[<mime type>][;charset=<charset>][;<encoding>],<encoded data>

;base64也是可选的部分。如果存在,则表示URI的数据内容是二进制数据,使用Base64方案以ASCII格式编码。由于base64方案会是文件增大 1 3 \frac{1}{3} 31?左右,所以data URI scheme一般用于较小的数据。

==<data>==表示数据。前面用**,**分隔。即使数据为空,这个,也不能丢掉。数据部分中允许的字符包括ASCII大写和小写字母,数字以及许多ASCII标点和特殊字符。如果数据是Base64编码的,则数据部分可能仅包含有效的Base64字符

例如

data:text/plain;charset=UTF-8;page=21,the%20data:1234,5678 (outputs: "the data:1234,5678"){ju5t_for_join}

平常我们用html插入图片是这样的

<img src="mages/image.jpeg">

然而用data URL scheme可以这样

<img src="">

前者我们打开这个图片时会发出HTTP请求,去访问外部资源,从而显示出来这张图片;

而后者则没有发出HTTP请求,直接从HTML文件中读取到文件的值,从而显示出来。

支持的类型

data:,                              文本数据
data:text/plain,                    文本数据
data:text/html,                     HTML代码
data:text/html;base64,              base64编码的HTML代码
data:text/css,                      CSS代码
data:text/css;base64,               base64编码的CSS代码
data:text/javascript,               Javascript代码
data:text/javascript;base64,        base64编码的Javascript代码
data:image/gif;base64,              base64编码的gif图片数据
data:image/png;base64,              base64编码的png图片数据
data:image/jpeg;base64,             base64编码的jpeg图片数据
data:image/x-icon;base64,           base64编码的icon图片数据

优缺点

可以减少对资源的请求;

可解决外部资源受限问题;


资源不会被浏览器缓存,每次访问都要重新获取;

可以放在样式表css中,与样式表一起被缓存;
资源会比原来的大 1 3 \frac{1}{3} 31?

  相关解决方案