一般开源项目都会有一些小徽章来标识项目的状态信息,并且这些信息是会自动更新的。在shields的官网上面有各种各样的小图标,并且有很多自定义的方案。
shields小徽章介绍
起因:如何给私有部署的jenkins制作shields服务?
私有部署的jenkins是用来打包docker镜像的,而我想获取最新的项目打包的jenkins镜像信息。但是私有的jenkins项目信息,公网的shields服务是无法获取其信息的。那么如果搭建一个私有的shields服务呢?
第一步:如何根据一些信息,制作svg图标
查看shields图标的源码,可以看到这些图标都是svg格式的图标。然后的思路就是,将文字信息转成svg图标。最后我发现这个思路是个死胡同,
有个npm包叫做,text-to-svg,似乎可以将文本转成svg,但是看了文本转svg的效果,果断就放弃了。
最后回到起点,看了shields官方仓库,发现一个templates目录,豁然开朗。原来svg图标是由svg的模板生成的,每次生成图标只需要将信息添加到模板中,然后就可以渲染出svg字符串了。
shields小徽章怎样
顺着这个思路,发现一个包shields-lightweight
varshields=require('shields-lightweight');
varsvgBadge=shields.svg('subject','status','red','flat');
所以我就fork了这个项目,重写了图标宽度计算的方式。shields-less
npminstallshields-less
varshieldsLess=require('shields-less')
varsvgBadge=shieldsLess.svg({
leftText:'npm黄河远上白云间',
rightText:'hello世界'
总之,这个包的确可以生成和shields一样的小徽章,但是如果徽章中有中文,那么中文就会溢出。因为一个中文字符的宽度要比一个英文字符宽很多。