favicon 俗称网站图标,作为网站的脸面每一个网站都不会少的,比如下图:
当在浏览器上我们打开网站的时候,浏览器会根据网站代码一般是:
<link rel="icon" href="/favicon.ico">
发送一个 HTTP 请求获取这个图标。
假如我们没有给网站指定图标的代码,浏览器依然会发送请求,默认请求网站根目录下的 favicon.ico
。
现在网站不想要网站图标,浏览器的默认图标请求就没有意义了,对服务器来讲浪费了一次 HTTP 请求,如何避免服务器接受浏览器这次无意义的请求呢?
网站需要的图标本身是一个图片,如果我们把需要的图片变成代码不就没有请求了吗,前端有什么技术可以用来表示(图片)文件呢?你肯定想到了 Base64。
浏览器有两个 API 可用:btoa 和 atob。
btoa("Hello, World!")
'SGVsbG8sIFdvcmxkIQ=='
atob('SGVsbG8sIFdvcmxkIQ==')
'Hello, World!'
现在还有一个问题,如何把 Base64 放到 link 标签的 href 中展示,这就是今天介绍的一个重点技术 Data URLs 技术,允许内联展示小文件。
Data URLs 的语法如下:
data:[<mediatype>][;base64],<data>
语法分为四部分:
- 必须的前缀:
data:
。 - 可选的
<mediatype>
描述数据的 MIME 类型,默认text/plain;
。 - 可选的
;base64
编码格式,默认charset=US-ASCII
。 - 数据本身。
所以根据语法最简单的一个符合 Data URLs 是 data:,
。
更多例子,例如展示一段文本 Hello, World!
data:text/plain;base64,SGVsbG8sIFdvcmxkIQ==
使用 Base64 展示一张 PNG 图片:

使用 Base64 展示 SVG图片:

还可以直接展示 SVG 图片:
data:image/svg+xml;charset=utf-8,%3Csvg%20version%3D%221.1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M267.168%20454.624v316.48h152V598.224c0-6.144%204.992-11.12%2011.136-11.12h169.728c6.16%200%2011.136%204.976%2011.136%2011.12v172.88h136V453.6l-239.36-188.848-240.64%20189.856z%20m-48%2037.872l-39.36%2031.04a16%2016%200%200%201-22.464-2.656l-9.904-12.56a16%2016%200%200%201%202.656-22.464l347.792-274.416a16%2016%200%200%201%2019.84%200l347.792%20274.4a16%2016%200%200%201%202.656%2022.48l-9.92%2012.56a16%2016%200%200%201-22.464%202.656l-40.624-32.048v292.48a35.136%2035.136%200%200%201-35.136%2035.136H254.304a35.136%2035.136%200%200%201-35.136-35.136V492.496z%20m248%20270.608h96v-128h-96v128z%22%20fill%3D%22%231296db%22%3E%3C%2Fpath%3E%3C%2Fsvg%3E
展示内容用到了 URL 编码(或叫百分比编码)
encodeURIComponent(`<svg version="1.1" xmlns="http://www.w3.org/2000/svg"><path d="M267.168 454.624v316.48h152V598.224c0-6.144 4.992-11.12 11.136-11.12h169.728c6.16 0 11.136 4.976 11.136 11.12v172.88h136V453.6l-239.36-188.848-240.64 189.856z m-48 37.872l-39.36 31.04a16 16 0 0 1-22.464-2.656l-9.904-12.56a16 16 0 0 1 2.656-22.464l347.792-274.416a16 16 0 0 1 19.84 0l347.792 274.4a16 16 0 0 1 2.656 22.48l-9.92 12.56a16 16 0 0 1-22.464 2.656l-40.624-32.048v292.48a35.136 35.136 0 0 1-35.136 35.136H254.304a35.136 35.136 0 0 1-35.136-35.136V492.496z m248 270.608h96v-128h-96v128z" fill="#1296db"></path></svg>`)
利用可编辑的 HTML 元素,甚至可以直接创建一个记事本:
data:text/html;charset=utf-8,<html contenteditable></html>
回到上面的问题,「如何避免浏览器对网站图标发起请求」,最简单的就是下面这样做:
<link rel="icon" href="data:,">
完~
灵感来源: