小程序本地iconfont工具开发

npm包:www.npmjs.com/package/min...

github: github.com/ahao430/min...

基于svgtofont开发。

背景:

平时小程序开发过程中,UI给的是一个个的svg,没有系统的iconfont维护。小程序端使用iconfont的话,首先要上传维护iconfont仓库,然后每次要转base64再下载,在项目中更新,比较麻烦。

在web端直接使用svg更加方便,如svg-sprite-loader,项目本地维护svg即可;但是小程序端svg只能作为图片使用。

思路:

svgtofont可以将本地的svg转成iconfont,但是看了文档,没有转成base64格式的选项,转base64的话,还是需要去iconmoon等网站工具。想到基于svgtofont生成的文件,继续转base64,再替换到css中,试验可行。

实现:

  1. svg转font

www.iconfont.cn/下载了几个svg图片,引入svgtofont,传入src和dist路径,运行报错,发现下下来的svg代码中包含xml的头部,删掉就成功运行。

安装svgo,先遍历svg目录,优化后svg头部去掉了。

再次运行,成果在dist目录生成iconfont的html,css,字体文件。

  1. font转base64

用fs.readFileSync读取ttf字体文件,再用Buffer.from(file).toString('base64')转成base64字符串。

查看网上手动转的base64格式iconfont的css,发现@font-face中,src的url换成了src: url("data:font/ttf;charset=utf-8;base64,xxxx")。读取css文件,用刚刚生成的base64字符串替换src中的部分,写到本地文件。

引入这个base64格式的iconfont.css文件,发现在小程序中可以正常使用class展示图片。也可以通过fontSize和color修改大小和颜色,说明转的base64格式可以正常使用。

  1. 导出base64的css

将刚刚写到本地的base64格式的字体css文件,复制到指定目录和文件名。

详细代码见github仓库。

相关推荐
崔庆才丨静觅12 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
passerby606113 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了13 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅13 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅13 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅14 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment14 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅14 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊14 小时前
jwt介绍
前端
爱敲代码的小鱼14 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax