【字体图标iconfont】字体图标部署流程+项目源码分析
迪丽瓦拉
2025-06-01 00:06:23
0

今日,心情甚是烦闷,原由…
公司项目需要将字体图标做一些细微的调整,我一人分析了许久,看不大懂源码的逻辑,产生了自我怀疑。深吸一口气,重新鼓起勇气,调整心境,一下子豁然开朗,所以决定写一份字体图标部署的教程,以此吸取教训和总结经验

1.前置知识

当我们从阿里巴巴矢量库将自己需要的图标都添加到项目中后【或者公司的UI已经为我们准备好了包含所需图标的项目】

  • 我们需要先把项目下载到本地
  • 在这里插入图片描述接下来将下载下来的文件解压,打开文件夹,找到以下文件
    在这里插入图片描述
  • 将上方红色框里面的所有文件都替换到项目的iconfont文件中【一般是在项目工程的project/assets/fonts/…目录下面】,自己找找看看都会找到的
    在这里插入图片描述
  • 所有字体文件都替换结束后,我们就得到一个全新的iconfont.css文件,里面使用伪类选择器,将类选择器与图标字体建立联系,比如放大图标,他的unicode值是e674,在 iconfont.css代码中.icon-fangda就代表着unicode值为e674的放大图标
    在这里插入图片描述

iconfont.css代码的一部分


.icon-fuzhi:before {content: "\e672";
}.icon-suoxiao:before {content: "\e673";
}.icon-fangda:before {content: "\e674";
}

2.遇到的问题

UI需要将项目左侧的图标替换成右侧图标,可是我看起来并没有太大的区别,可能UI有它自己的想法
图标前后对比
核心代码

循环遍历每一个图标,通过class动态绑定样式,可能大家看到a-tooptip会觉得这是个什么东西,不要担心,我们可以把它看成一个普通的组件,本文不对它做出讨论…,代码的关键之处在于span标签绑定的动态样式,以放大图标为例,span对应的class值为 icon-fangda,而 icon-fangda就代表着放大图标,span 标签内部::before元素就是我们需要的放大图标【相信从头看下来的小伙伴们已经懂了】


图标数据

  tools: [{key: 'zoomIn',icon:'icon-fangda',name: `放大 ${optionsText}+加号;${optionsText}+鼠标滚轮`,},{key: 'zoomOut',icon:'icon-suoxiao',name: `缩小 ${optionsText}+减号;${optionsText}+鼠标滚轮`,},{key: 'copy',icon: 'icon-fuzhi',name: `复制当前图片标注信息 ${optionsText}+C`,},{key: 'icon-niantie',icon: 'icon-niantie',name: `粘贴已复制标注信息 ${optionsText}+V`,},{ key: 'delete', icon: 'icon-lajitong', name: '删除' },],

相关内容