什么是 Data URL
Data URL 是前缀为 data:
协议的 URL,允许在 URL 中直接嵌入数据,与常见的 URL(如 https://
)不同,Data URL 不指向外部资源,而是直接包含数据内容。这种方式可以用于在网页或应用程序中内联小型的文件或数据片段,而无需从外部服务器加载。这种协议常用于网页、演示文档或者应用中嵌入小片段的 Markdown 文本而无需访问外部文件。
举个例子,你可以直接在网页中打开下面的链接,打开之后会在网页上展示一段 markdown 文本
data:text/markdown;base64,IyMgSGVsbG8gV29ybGQKVGhpcyBpcyBhIG1hcmtkb3duIHRleHQK
展示的内容为
## Hello World
This is a markdown text
Data URL 格式
典型的 Data URL 格式如下:
data:[<MIME-type>][;base64],<data>
MIME-type
: 数据的媒体类型,如text/html
、image/png
、text/markdown
等。base64
: 如果数据经过 Base64 编码,该部分会包含;base64
。<data>
: 实际的数据,可以是文本或二进制内容。
还是以上面的例子介绍一下
对于 Data URL data:text/markdown;base64,IyMgSGVsbG8gV29ybGQKVGhpcyBpcyBhIG1hcmtkb3duIHRleHQK
, 其实是内嵌的 Markdown 文本文件,它使用 text/markdown
作为媒体类型,数据部分采用base64
编码,也就是将 markdown
文本使用 base64
进行压缩。不过不用担心在浏览器中展示的是编码后的base64
编码,浏览器会自己解码,最终展示的是解码之后的markdown
文本。
当然你也可以不使用base64
进行压缩,但是需要进行 urlEncode
,像下面这样,在浏览器中打开的效果是一样的
data:text/mardkwon,%23%23+Hello+World%0aThis+is+a+markdown+text%0a
使用场景
其实这个东西并不陌生,比如我们在网页中使用base64 编码展示图片用的就是这个协议
.example {
background-image: url(...);
}
下面整理了几个比较常用的场景
1. 内嵌图像资源
- 使用场景: 为了避免在加载页面时额外的 HTTP 请求,将小型图像、svg 图标直接嵌入 HTML 或 CSS 中。
- 示例: 在 CSS 中嵌入背景图像:
.logo {
background-image: url(...);
}
- 好处: 减少网络请求次数,提升网页加载速度,尤其在网络环境不佳的情况下很有帮助。
2. Web 应用中做文件导出
- 使用场景: 某些场景中提供一些小文件的下载链接。
- 示例:比如导出 JSON 文件:
<a href="data:application/json;base64,eyB0aXRsZTogJ2hlbGxvIHdvcmxkJyB9" download="data.json">JSON</a>
- 好处: 无需依赖服务器生成文件,前端可以动态生成文件并提供下载。
3. 前端演示或沙盒应用
- 使用场景: 在需要在线编辑和预览文件的应用中,可以使用 Data URL 来生成实时预览。
- 示例: 比如展示 markdown 文本。
<iframe src="data:text/markdown;base64,SGVsbG8gd29ybGQhIFRoaXMgaXMgYSBtYXJrZG93biB0ZXh0Lg==" />
- 好处: 无需将内容发送到服务器,即可在本地生成实时预览。
4. 简易的网页应用
- 使用场景: Data URL 可以用于创建完全独立的网页应用或演示文件,不需要任何外部服务器资源,甚至可以离线运行。在一些特殊的情况下,网络不可用或不便于发送请求,Data URL 可以作为替代方案,提供本地渲染或数据存储的解决方案。
- 示例: 使用 Data URL 创建一个简单的组件预览页,你可以复制下面的 base64 到浏览器打开,可以看到一个按钮组件的预览页面
data:text/html;base64,PCFET0NUWVBFIGh0bWw+CjxodG1sIGxhbmc9InpoIj4KPGhlYWQ+CiAgICA8bWV0YSBjaGFyc2V0PSJVVEYtOCI+CiAgICA8bWV0YSBuYW1lPSJ2aWV3cG9ydCIgY29udGVudD0id2lkdGg9ZGV2aWNlLXdpZHRoLCBpbml0aWFsLXNjYWxlPTEuMCI+CiAgICA8dGl0bGU+5oyJ6ZKu54q25oCB56S65L6LPC90aXRsZT4KICAgIDxzdHlsZT4KICAgICAgICBib2R5IHsKICAgICAgICAgICAgZm9udC1mYW1pbHk6IEFyaWFsLCBzYW5zLXNlcmlmOwogICAgICAgICAgICBkaXNwbGF5OiBmbGV4OwogICAgICAgICAgICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjsKICAgICAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjsKICAgICAgICAgICAgaGVpZ2h0OiAxMDB2aDsKICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogI2Y0ZjRmNDsKICAgICAgICB9CgogICAgICAgIC5idXR0b24gewogICAgICAgICAgICBwYWRkaW5nOiAxNXB4IDMwcHg7CiAgICAgICAgICAgIGZvbnQtc2l6ZTogMTZweDsKICAgICAgICAgICAgY29sb3I6IHdoaXRlOwogICAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjMDA3YmZmOwogICAgICAgICAgICBib3JkZXI6IG5vbmU7CiAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6IDVweDsKICAgICAgICAgICAgY3Vyc29yOiBwb2ludGVyOwogICAgICAgICAgICB0cmFuc2l0aW9uOiBiYWNrZ3JvdW5kLWNvbG9yIDAuM3MsIHRyYW5zZm9ybSAwLjJzOwogICAgICAgICAgICBtYXJnaW46IDEwcHg7CiAgICAgICAgfQoKICAgICAgICAuYnV0dG9uOmhvdmVyIHsKICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogIzAwNTZiMzsKICAgICAgICB9CgogICAgICAgIC5idXR0b246YWN0aXZlIHsKICAgICAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogIzAwNDA4NTsKICAgICAgICAgICAgdHJhbnNmb3JtOiBzY2FsZSgwLjk1KTsKICAgICAgICB9CgogICAgICAgIC5idXR0b246ZGlzYWJsZWQgewogICAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjYzBjMGMwOwogICAgICAgICAgICBjdXJzb3I6IG5vdC1hbGxvd2VkOwogICAgICAgIH0KICAgIDwvc3R5bGU+CjwvaGVhZD4KPGJvZHk+CgogICAgPGJ1dHRvbiBjbGFzcz0iYnV0dG9uIj7mraPluLjnirbmgIE8L2J1dHRvbj4KICAgIDxidXR0b24gY2xhc3M9ImJ1dHRvbiIgb25tb3VzZW92ZXI9InRoaXMuaW5uZXJIVE1MPSfmgqzlgZznirbmgIEnIiBvbm1vdXNlb3V0PSJ0aGlzLmlubmVySFRNTD0n5q2j5bi454q25oCBJyI+5oKs5YGc54q25oCBPC9idXR0b24+CiAgICA8YnV0dG9uIGNsYXNzPSJidXR0b24iIG9ubW91c2Vkb3duPSJ0aGlzLmlubmVySFRNTD0n5oyJ5LiL54q25oCBJyIgb25tb3VzZXVwPSJ0aGlzLmlubmVySFRNTD0n5q2j5bi454q25oCBJyI+5oyJ5LiL54q25oCBPC9idXR0b24+CiAgICA8YnV0dG9uIGNsYXNzPSJidXR0b24iIGRpc2FibGVkPuemgeeUqOeKtuaAgTwvYnV0dG9uPgoKPC9ib2R5Pgo8L2h0bWw+Cg==
- 好处:
-
- 在一些特殊的情况下,网络不可用或不便于发送请求,Data URL 可以作为替代方案,提供本地渲染或数据存储的解决方案。
- 对于一些需要可视化交流的内容能够提升用户体验。
其他
兼容性
从 MDN 看 Data URL 的兼容性还是不错的 Data URL | MDN (mozilla.org)
安全性
浏览器会将 Data URL 视为唯一的不透明来源,意味着浏览器将 Data URL 视为一种安全策略,限制了这些 URL 在某些场景下的使用,比如你无法通过window.open
打开 Data URL,你也无法通过 fetch
请求 Data URL,就连localstorage
也无法访问。
可以传输的数据大小
实际还没有进行测试,如果 MDN 上描述的没有问题,那这个数据量也是很惊人的
查阅一些资料后,有一些文章中提到限制是:
- Google Chrome: 大约 2 MB
- Firefox: 大约 2 MB
- Safari: 大约 650 KB
- Microsoft Edge: 大约 2 MB
总结一下
优势:
- 减少网络请求: 减少了对服务器的请求,优化了页面加载速度。
- 独立性: 数据和资源可以完全内嵌,确保内容独立于外部服务器。
局限
- 文件大小限制: 浏览器对 Data URL 的大小有限制,通常不能超过 2 MB。
- 可维护性差: 内嵌数据不容易维护,尤其是当嵌入的内容较大或复杂时候,不像在线应用那样可以在线更新。
- 不利于 SEO: 如果过多使用 Data URL,尤其是在 HTML 中,可能会对搜索引擎优化(SEO)不利,因为外部引用的资源更容易被索引。