小程序本地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仓库。

相关推荐
繁依Fanyi14 分钟前
Animaster:一次由 CodeBuddy 主导的 CSS 动画编辑器诞生记
android·前端·css·编辑器·codebuddy首席试玩官
想起你的日子22 分钟前
Android studio 实现弹出表单编辑界面
java·前端·android studio
LuckyLay1 小时前
Vue百日学习计划Day9-15天详细计划-Gemini版
前端·vue.js·学习
weifont5 小时前
聊一聊Electron中Chromium多进程架构
javascript·架构·electron
大得3695 小时前
electron结合vue,直接访问静态文件如何跳转访问路径
javascript·vue.js·electron
水银嘻嘻7 小时前
12 web 自动化之基于关键字+数据驱动-反射自动化框架搭建
运维·前端·自动化
it_remember7 小时前
新建一个reactnative 0.72.0的项目
javascript·react native·react.js
小嘟嚷ovo8 小时前
h5,原生html,echarts关系网实现
前端·html·echarts
十一吖i8 小时前
Vue3项目使用ElDrawer后select方法不生效
前端
只可远观8 小时前
Flutter目录结构介绍、入口、Widget、Center组件、Text组件、MaterialApp组件、Scaffold组件
前端·flutter