抱歉,您的浏览器无法访问本站
本页面需要浏览器支持(启用)JavaScript
了解详情 >

引言

Shields.io是一个为我们提供自定义徽章的文章。在GitHub的很多仓库我们都能见到像这样的徽章,它们绝大多数都使用Shields.io制作。但是我们在使用logo时,由于其logo库使用Simple Icons,所以只有国际知名的品牌logo能在上面找到。那么,当我们想要使用自己定义的logo时,就不能仅凭logo=xxx这样简单的代码实现了。

官网描述

查看官网我们得到这样的信息。发现Shields.io其实是允许我们插入自定义logo图片的,但是要求是高度大于等于14px且http的请求头不能超过8192字节。只要知道文件Base64编码的DataURL形式就可以了。

图片准备

裁剪压缩图片

使用png格式图片进行裁剪压缩,我直接用的在线工具:

建议将图片裁剪压缩到5k左右,这样能使http请求头尽量小。况且徽章小,图片文件小些没关系

获取图片Base64编码的DataURL形式

推荐大佬做的工具

如下图,选择你的logo图片(png格式)

将这一串字符全选复制。

拼接至URL中

格式为:

1
https://img.shields.io/badge/左边文字-右边文字-右边颜色?logo=data:image/png;base64,刚刚复制的那串字符

比如我的页脚Copyright徽章,URL为

1
https://img.shields.io/badge/Copyright%402022-Bowen%20Young-%23EF9421?logo=

效果为:

补充

上文data:image/png;base64,…这种形式被称为Data URL Scheme

Data URL Scheme的作用,一般就是将经过Base64编码的数据嵌入网页中,从而减少请求资源的链接数。 上面的Data URL Scheme中 base64, 后的字符就是经过base64编码后的数据,浏览器会对其解码并渲染该图片资源。

评论