Young Kbt blog Young Kbt blog
首页
  • java基础

    • Java基础
    • Java集合
    • Java反射
    • JavaJUC
    • JavaJVM
  • Java容器

    • JavaWeb
  • Java版本新特性

    • Java新特性
  • SQL 数据库

    • MySQL
    • Oracle
  • NoSQL 数据库

    • Redis
    • ElasticSearch
  • 数据库

    • MyBatis
    • MyBatis-Plus
  • 消息中间件

    • ActiveMQ
    • RabbitMQ
    • RocketMQ
    • Kafka
  • 进阶服务

    • Nginx
  • Spring
  • Spring Boot
  • Spring Security
  • 设计模式
  • 算法
  • 知识
  • 管理

    • Maven
    • Git
  • 部署

    • Linux
    • Docker
    • Jenkins
    • Kubernetes
  • 进阶

    • TypeScript
  • 框架

    • React
    • Vue2
    • Vue3
  • 轮子工具
  • 项目工程
  • 友情链接
  • 本站

    • 分类
    • 标签
    • 归档
  • 我的

    • 收藏
    • 关于
    • Vue2-Admin (opens new window)
    • Vue3-Admin(完善) (opens new window)
GitHub (opens new window)

Shp Liu

朝圣的使徒,正在走向编程的至高殿堂!
首页
  • java基础

    • Java基础
    • Java集合
    • Java反射
    • JavaJUC
    • JavaJVM
  • Java容器

    • JavaWeb
  • Java版本新特性

    • Java新特性
  • SQL 数据库

    • MySQL
    • Oracle
  • NoSQL 数据库

    • Redis
    • ElasticSearch
  • 数据库

    • MyBatis
    • MyBatis-Plus
  • 消息中间件

    • ActiveMQ
    • RabbitMQ
    • RocketMQ
    • Kafka
  • 进阶服务

    • Nginx
  • Spring
  • Spring Boot
  • Spring Security
  • 设计模式
  • 算法
  • 知识
  • 管理

    • Maven
    • Git
  • 部署

    • Linux
    • Docker
    • Jenkins
    • Kubernetes
  • 进阶

    • TypeScript
  • 框架

    • React
    • Vue2
    • Vue3
  • 轮子工具
  • 项目工程
  • 友情链接
  • 本站

    • 分类
    • 标签
    • 归档
  • 我的

    • 收藏
    • 关于
    • Vue2-Admin (opens new window)
    • Vue3-Admin(完善) (opens new window)
GitHub (opens new window)
  • 工具使用

    • 工具介绍
    • Shields - 徽章
      • 介绍
      • 静态徽章
        • 介绍
        • 例子
      • 端点徽章
        • 例子
        • 总结:
      • 动态徽章
        • 例子1
        • 例子2
      • 美化
        • 图标的显示
        • 标签的颜色
        • 图标的颜色
      • 图标徽章
    • DBeaver - SQL连接器
    • Log4j - 配置
  • 收藏夹

  • 轮子工具
  • 工具使用
Young Kbt
2021-10-29
目录

Shields - 徽章

# 介绍

如果你曾在很多地方看到如下徽章:

stars

kbt

如果你也对此眼热,想自己的主页或者其他地方有类似的徽章,那么 Shields 会满足你。

Shields 官网 (opens new window)

如果你想看更多的 Shields 例子,可以看 自我 - 介绍。

# 静态徽章

进入 Shields 网站,会看到密密麻麻的英文,如果看不懂,可以使用谷歌翻译。

往下滑,找到如图所示:

image-20211029142418498

圈住的红框代表这是静态的徽章设计区域,即设计出来的徽章是固定的,不是动态的。

静态的徽章设计很简单,如果记得格式,不需要每次都来官网设计,直接敲 url 对应的格式即可

# 介绍

静态徽章的 url 格式如上图:https://img.shields.io/badge/<LABEL>-<MESSAGE>-<COLOR>,也就是 https://img.shields.io/badge/{左标签文本}-{右消息文本}-{右消息背景颜色}。

只需要在三个文本框输入想要的内容即可,并点击Make Badge,这三个参数从左到右分别为左边内容、右边内容、右边背景色

如下图:

image-20211029143002244

最后生成的内容为

image-20211029143121551

结合上方图片的不同的颜色箭头,再根据 url 的格式可以得出总结、理解这个格式:https://img.shields.io/badge/<LABEL>-<MESSAGE>-<COLOR>,需要改变的是 <LABEL>、<MESSAGE>、<COLOR>

只要记住了 Shields 的 url 前缀,通过手动输入 url 也可以自动生成徽章,不需要来到官网。

官方提供的颜色有:

brightgreen green yellowgreen yellow orange red blue lightgrey

success important criticalinformational inactive

blueviolet ff69b4 9cf

如果你需要其他颜色,输入颜色的十六进制即可,如黑色:#000000。

提示

三个参数之间用 - 隔开,如果前两个参数想要出现空格,比如 spring boot,需要输入 spring%20boot,因为 url 无法直接识别空格,但是却可以知道 %20 代表空格。

2021-10-29 @Young Kbt

在 Markdown 里,直接使用徽章生成的 url 地址并不会生成徽章,它仅仅只是一个 url,生成徽章的格式:

![一些描述](徽章生成的 url 地址)
1

# 例子

需求:左边内容为 vuepress,右边为 vdoing,颜色为红色

只需在网址上敲:https://img.shields.io/badge/vuepress-vdoing-red即可

image-20211029143726402

颜色请参考官网给出的:

image-20211029143944037

# 端点徽章

端点徽章既不是意义上的静态徽章也不是动态徽章,但是也可以说是静态徽章,下面会给出解释

看图:

image-20211029144955047

可知它的 url 格式为:https://img.shields.io/endpoint?url=<URL>&style<STYLE>

而其中 https://img.shields.io/endpoint? 是固定的,只需要改后面的参数即可,参数其实有很多个,点击箭头指示的地址跳转查看

图片太大,点击可打开,再点击会折叠

image-20211029145214730

参数虽然很多,但是常用的不多,就是 url,type,label,color

根据上方图片点击箭头指示的位置后,进入到跳转的页面,往下滑,找到如图所示:

image-20211029145452521

提示

红色框的内容就是你的 url 地址

很多人不懂 url 要干什么的,如果你学过后端的 Spring,就懂了,输入一个 url 地址,就会返回 json 格式的信息,这个信息就是徽章的右侧内容

2021-10-29 @Young Kbt

url 返回的 json 格式必须有 label、message

具体内容可看例子,下面介绍图片里的参数

参数介绍,点击打开,再次点击折叠
  • style:徽章的形状,可以根据的需求选择,都是些大小,有无圆角之类的形状

  • override label:覆盖徽章的左侧内容。因为 url 返回的 json 需要一个 label,即左侧内容,如果不需要 url 返回的,可以用子此参数进行覆盖

  • override color:覆盖违章的右侧背景色。同理不需要 url 返回的 color,可以覆盖

  • name logo:只是一个 logo 名字,不会影响徽章的内容,logo 指的是左侧的图标,具体看图标徽章大概。

  • override logo color:覆盖徽章 logo 的颜色,不会影响徽章的内容

# 例子

需求1:生成一个徽章。左侧内容为可乐,右侧内容为 Kbt

  1. 首先需要一个 url,返回的是 json 格式,必须有 label、message参数。我使用 Fast Mock (opens new window) 接口工具进行数据获取。如图:

    image-20211029151018526

  2. 工具会给我一个 url 地址,这里安全考虑就不写出来了

  3. 把这个 url 粘贴到上图的红色框里,然后 Shields 会请求这个 url,获得 label 为可乐,message 为Kbt。如图:

    image-20211029151439702

需求2:徽章左侧内容覆盖为冰糖。徽章右侧背景色改为蓝色

  1. 只需要在 override label 填入 冰糖,override color 填入 blue 即可

    image-20211029151824514

回归开头的解释,应该都知道端点徽章另类的静态徽章,如果想要修改内容,只需要在 url 返回的内容里修改,徽章随之修改。

# 总结:

静态徽章要在 url 里修改

端点徽章要在 url 的源头(响应数据里)修改

# 动态徽章

动态徽章用处比较广,一般用于网站统计访问量、评论区的数量等等。

实际上是动态的端点徽章,因为访问量,评论量变化时,url 返回的数据也会改变,这就是动态。

位置在端点徽章的下面,如图:

image-20211029152626540

格式为:

https://img.shields.io/badge/dynamic/json?url=<API请求网址>&label=<左标签文本>&query=<JSON的键>&color=<右消息背景颜色>&prefix=<前缀>&suffix=<后缀>

可以看出参数很多。它相比较端点徽章的特点:多了个请求参数,也就是 query,不需要整个 url 的内容。点击 data type 下拉菜单,知道返回的内容支持 json、xml、yaml。

图片的参数,点击打开,再次点击折叠
  • data type
  • label:徽章左侧内容
  • data url:url 地址
  • query:url 后面的请求内容。就是 url?xxx=??...
  • color:徽章右侧背景色
  • prefix:或者右侧内容的前缀
  • suffix:或者右侧内容的后缀

提示

动态徽章的真正用途,看例子 2,例子 1 只是简单的 demo,便于理解,实际不会用

2021-10-29 @Young Kbt

# 例子1

需求:徽章左侧内容为可乐,右侧内容为 Young Kbt,前缀加上 this is,后缀加上 's Blog,右侧颜色为蓝色

  1. 利用 Fast Mock (opens new window) 工具设置 url 返回的数据,我这里使用 json 格式,如图:

    image-20211029154940821

    注意

    name 只是随便写的,不一定是 name,根据需求决定

    2021-10-29 @Young Kbt

  2. 填写结果如图:(下图 name 对应上方图片的 name)

    image-20211118015804535

  3. 点击 Make Badge,效果如下:

    image-20211029154305068

实际就是请求了 url?query=info,得到结果,显示在右侧。即 key=value 格式。

# 例子2

实际上需要用到统计网站访问量等等

前提:你必须知道你的网站关于访问量的参数是什么

需求:统计自己的 GitHub 某个仓库的访问量

网址格式:

![stars](https://img.shields.io/github/stars/用户名/仓库名)
1

如我的notes-blog仓库可以写成

![stars](https://img.shields.io/github/stars/Kele-Bingtang/notes-blog)
1

效果:

stars

可以看出:例子 2 和例子 1 的区别犹如天壤之别,其实例子 2 才是实际用到的,因为例子 1 是自己规定的 url 和参数,例子 2 是其他人规定的 url,现在流行的 url 规范是 Restful 风格的格式。所以不太一样。

# 美化

参考:http://www.zhangkexuan.cn/2020/11/02/git-badge-substats/。

# 图标的显示

可以在 URL 中加入 &logo=bilibili,效果如下:

img

图标需要去 simpleicons (opens new window) 去按名称搜索,如果有,就可以直接用图标的名字。

例如我可以改成 &logo=Gmail

效果则变成这样:

img

如果 simpleicons 没有你想要的图标,你可以用自定义图标。

自定义图标需要传入图标的 base64 编码,例如 simpleicons 没有网易云音乐的图标,我就必须自己找一张网易云的 svg 图标,转成 base64 格式,可以在这个网上进行转换:https://www.css-js.com/tools/base64.html。

图标可以在 easyicon.net 找:https://www.easyicon.net (opens new window)。

也有其他很多的 SVG 图标搜索网都可以看看。

这里我 在 easyicon 搜索网易云音乐 (opens new window)。

拖入网易云音乐 logo 的 SVG 格式图片文件到上面说的转换网址,取消勾选「使用在CSS中」,点击「Copy code」,得到 base64 编码到剪切板:

tobase64


1

然后就可以传入

&logo=
1

效果:

网易云音乐

可以看到,成功显示网易云音乐的 logo。

# 标签的颜色

可以再加参数 &labelColor={颜色值}

例如之前的bilibili例子,我想让标签是粉色 FE7398

那么我加上一个参数 &labelColor=FE7398

效果为:

img

当然,和之前一样,支持已有的英文备选值。填入 pink 估计效果不会差太远。

但是现在图标的颜色是蓝色,又有点和白色的文字不太协调,和粉色的对比度也不高,我觉得白色更合适,怎么办呢?

# 图标的颜色

加上参数 &logoColor={颜色值} 即可。

我这里加上 &logoColor=white 来看看效果:

img

# 图标徽章

目前没有需求用到,所以暂时没更这个

大概讲下,就是在徽章左侧内容加了个图标,也就是 url 后面加了 logo=?,其中 ? 就是图标的名字。

image-20211029160654476

Shields 支持输入 simple-icons (opens new window) 图标网站的提供的图标名字,即可显示图标,也就是 ?logo=该图标网站的图标名字。

编辑此页 (opens new window)
#徽章
更新时间: 2023/10/23, 10:58:52
工具介绍
DBeaver - SQL连接器

← 工具介绍 DBeaver - SQL连接器→

最近更新
01
技术随笔 - Element Plus 修改包名 原创
11-02
02
Reactor - 扩展性
11-02
03
Reactor - 最佳实践
11-02
更多文章>
Theme by Vdoing | Copyright © 2021-2024 Young Kbt | blog
桂ICP备2021009994号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式