用 Shields.io 定制 README 个性徽章

大家好,我是费益洲。Github 项目中,可以看到很多 README 文档中都会有各式各样的徽章。我们可以借助这些徽章来显示某些状态。这些徽章,从原理上来说,都是我们给渲染服务器提供一些数据,然后渲染服务器会返回给我们一个 SVG 格式的图片,然后我们将图片嵌入 MD 文档中,即可渲染出来定制的徽章

简介

Shields.io 就是一个主流的渲染服务器,可以在官网上查看官方文档。总的来说,定制徽章的主要工作就是拼接符合渲染服务器规则的 URL,拼接好 URL 后,我们只要将 URL 嵌入 MD 文档即可。接下来简单介绍符合 Shields.io 规则的 URL 拼接方法。

静态徽章

静态徽章即徽章内容是固定不变的

基本规则

shields.io 的 URL 的基本规则即:base url + 定制参数:

  • base url: img.shields.io/badge/
  • 定制参数:定制参数根据徽章的颜色区间分为三部分,使用-间隔,分别为:
    • 左半部分标签:空格使用_代替,shields.io 会自动解析为空格
    • 右半部分标签:空格使用_代替,shields.io 会自动解析为空格
    • 右半部分颜色:支持十六进制(不带#)/颜色名称

整体结构如下所示:

http 复制代码
https://img.shields.io/badge/{左半部分}-{右半部分}-{右半部分颜色}

我们以左半部分为feiyizhou,右半部分为个人博客,颜色为蓝色为例:

http 复制代码
https://img.shields.io/badge/feiyizhou-个人博客-blue

在浏览器访问后即可看到下图:

⚠️ 颜色指定需要注意以下两个规则:

  • 如果需要指定左半部分,那么整个徽章只能是作为一个整体进行渲染(不再存在右半部分)
  • 左右两部分不能同时指定颜色,否则 shields 会解析异常

作为一个整体的徽章,整体规则如下所示:

http 复制代码
https://img.shields.io/badge/{标签}-{颜色}

我们以标签为feiyizhou,颜色为黑色为例:

http 复制代码
https://img.shields.io/badge/feiyizhou-black

在浏览器访问后即可看到下图:

增加 logo 的方式可以查看官方文档,此处做简单介绍总结。在上一步基础规则下,增加两个参数,即可为徽章增加指定的 logo:

  • logo:格式为 svg 的 logo 图片的名称
  • logoColor:logo 图片的颜色,支持十六进制(不带#)/颜色名称

增加 logo 后的整体结构如下所示:

http 复制代码
https://img.shields.io/badge/{左半部分}-{右半部分}-{右半部分颜色}?logo={logo名称}&logoColor={logo颜色}

shields.io 支持SimpleIcons网站里的所有 logo,用户可以在网站内搜索自己想要的 logo。也可以在 github 项目simple-icons中,搜索想要的 logo。

我们以熟练使用 etcd 为例,定制一个左半部分为Etcd,右半部分为熟练颜色为绿色,logo 颜色为白色徽章,URL 如下所示:

http 复制代码
https://img.shields.io/badge/Etcd-熟练-green?logo=etcd&logoColor=white

在浏览器访问后即可看到下图:

shields.io 除了支持 SimpleIcons 中的 logo,还支持通过 base64 格式的数据指定 logo,需要做的就是将 svg 转为 base64 格式的数据,带入 URL 中即可。

通过 base64 格式增加 log 的整体格式如下所示:

http 复制代码
https://img.shields.io/badge/{左半部分}-{右半部分}-{右半部分颜色}?logo=data:image/svg+xml;base64,{base64数据}

我们以熟练使用 SQLite 为例,定制一个左半部分为SQLite,右半部分为熟悉颜色为黄色徽章,URL 如下所示:

http 复制代码
https://img.shields.io/badge/SQLite-熟悉-yellow?logo=

在浏览器访问后即可看到下图:

⚠️ 需要注意的时,如果使用 base64 数据传递 logo,参数logoColor则会失效

动态徽章

动态徽章是相对于静态徽章的,即徽章内容是动态渲染的,所以内容也是可以发生变化的

shields.io 提供了多种动态徽章的使用方式,比较常用的有两种:一种是指定获取特定格式数据的 URL,并指定需要解析的参数以及徽章的各类参数,最后由 shields 动态渲染。另外一种就是一些指定平台的指定参数的动态渲染。

📚 关于动态徽章的使用官方文档已经做了很详细的说明,而且有详细的样例,同志们可以自行查阅观看。shields 还支持 TOML、XML、YAML 等格式的数据,下面简单的对解析 JSON 格式数据的动态徽章和特定平台的动态徽章做简单总结性介绍。

Dynamic JSON Badge

通过指定的 URL 获取 JSON 数据,并解析出需要的数据并动态渲染数据。

整体结构体如下所示:

http 复制代码
https://img.shields.io/badge/dynamic/json

参数较多,这里只列举两个必填参数

指定部分参数后,整体 URL 如下所示:

http 复制代码
https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fgithub.com%2Fbadges%2Fshields%2Fraw%2Fmaster%2Fpackage.json&query=%24.homepage&style=flat&logo=appveyor&logoColor=white&label=homepage&labelColor=black&color=blue

在浏览器访问后即可看到下图:

💡 动态徽章里面比较特殊的就是 Endpoint Badge。这中动态徽章支持用户自己搭建徽章数据响应站点,shields 通过这个站点获取到数据后再进行动态渲染。需要注意的是,响应的数据需要遵从 shields 的参数要求。具体使用方式及参数要求同志们可以自行查阅官方文档

Github followers

这个动态徽章就只是用来显示指定用户的 GitHub 的 follower 数量

整体结构如下所示:

http 复制代码
https://img.shields.io/github/followers/{Github用户名}

以我自己为例,URL 如下所示:

http 复制代码
https://img.shields.io/github/followers/feiyizhou

在浏览器访问后即可看到下图:

相关推荐
年轻的麦子3 小时前
Go 框架学习之:Fx 简单测试示例:fx.Options() 和 fx.Replace()
后端
年轻的麦子3 小时前
Go 框架学习之:初识go.uber.org/fx
后端
这里有鱼汤3 小时前
反转还是假象?华尔街奇才的神秘指标:Python实战神奇九转(含代码)量化小白必看
后端·python
_新一4 小时前
Go Slice源码解析
后端·go
码事漫谈4 小时前
C++开发中的常用设计模式:深入解析与应用场景
后端
dl7434 小时前
@Resource依赖注入原理
后端
码事漫谈4 小时前
当公司在你电脑上安装了IP-guard,你必须知道的事
后端
麦兜*4 小时前
MongoDB 高可用部署:Replica Set 搭建与故障转移测试
java·数据库·spring boot·后端·mongodb·spring cloud·系统架构
汤姆yu4 小时前
2025版基于springboot的电影购票管理系统
java·spring boot·后端·电影购票