现在的位置: 首页 > web前端 > 正文

shields的小图标

2020年07月03日 web前端 ⁄ 共 889字 ⁄ 字号 评论关闭

  一般开源项目都会有一些小徽章来标识项目的状态信息,并且这些信息是会自动更新的。在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一样的小徽章,但是如果徽章中有中文,那么中文就会溢出。因为一个中文字符的宽度要比一个英文字符宽很多。

抱歉!评论已关闭.