在ElementUI项目中集成iconfont图标库

在前端项目开发中经常会遇到使用的组件库提供的ICON图标不够用的情况。最常见的解决方案无非就是把设计图的图标切图引入到项目中。还有就是使用svg图标,封装一个渲染组件在项目里面直接引入这个组件。

本文将介绍另一种方法,即集成iconfont图标库的图标到项目中去,用最小化的改动满足图标需求。

快速开始

1、打开阿里巴巴的图标库网站:阿里巴巴矢量图标库,登录自己的账号。

完成这一步你会看到这样的界面。

2、搜索你需要的图标,然后选中你需要的图标,点击添加购物车,步骤如下图所示:

3、点击菜单栏购物车之后,弹出下面的页面,点击添加至项目。在弹出的侧栏里面选择要把图标添加到的项目,如果没有项目就新建。

4、把图标加入到指定的项目后,点击确定你就会跳转到项目详情页面,在这个页面点击项目设置,对图标前缀和字体名称做一些简单的设置,如下图。

修改完成后,点击保存。

5、下载图标文件到本地

  • iconfont.ttf、iconfont.woff、iconfong.woff2 是图标字体文件,可以把它们复制到你的项目中的 fonts 目录下。

  • iconfont.css 是 Font Class 方式使用图标的CSS代码,内容如下,但是记得修改图标字体文件的路径

    @font-face {
    font-family: "element-icons";
    src: url('iconfont.woff2?t=1709537603593') format('woff2'),
    url('iconfont.woff?t=1709537603593') format('woff'),
    url('iconfont.ttf?t=1709537603593') format('truetype');
    }

    .element-icons {
    font-family: "element-icons" !important;
    font-size: 18px;
    font-style: normal;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    }

    .el-icon-xitong:before {
    content: "\e67c";
    }

6、把 iconfont.css 引入到项目中,在需要的地方就可以使用类名 el-icon-xitong 使用我们刚刚添加到项目中的图标了。

复制代码
<i class="el-icon-xitong"></i>

总结

本文试图提供一种方便快捷的方法,帮助开发人员将iconfont图标集成到他们的前端项目中,满足项目对图标的需求。介绍了阿里巴巴图标库网站的使用方式,以及如何对图标项目进行设置,让这些图标可以直接在element-ui项目中应用。

在现在的项目中main.js引入字体图标的css样式

7、在组件当中就可以使用。使用之前要加iconfont。

相关推荐
idcu5 分钟前
Lyt.js AI:让前端开发进入智能生成时代
前端
idcu5 分钟前
深入 Lyt.js 编译器:.lyt 文件如何增强 HTML 模板能力
前端
即答侠5 分钟前
实时 AI copilot 的 4 级 fallback 设计:用户感知 0 中断,SLA 从 92% 拉到 99.6%
前端·人工智能
无心使然8 分钟前
Openlayers调用ArcGis地图服务之五 —— 要素识别(/identify)
前端·vue.js·数据可视化
Dxy123931021614 分钟前
HTML 如何设置 Div 阴影悬浮边框:从基础到进阶
前端·html·css3
好运的阿财15 分钟前
OpenClaw工具拆解之browser+agents_list
前端·人工智能·机器学习·开源软件·ai编程·openclaw·openclaw工具
JarvanMo22 分钟前
八个开源Flutter应用,让你成为更好的开发者
前端
ZC跨境爬虫27 分钟前
Apple官网复刻第二阶段day_2:(前端模块化还原苹果官网WATCH海报)
前端·ui·重构·html·状态模式
李李李勃谦30 分钟前
Vue3 + Electron + OpenHarmony 跨平台实战:从架构设计到 Markdown 编辑器完整实现
javascript·华为·electron·编辑器·harmonyos
Rabbit_QL31 分钟前
【前端基础】npm install 是干嘛的(带参数 vs 不带参数)
前端·npm·node.js