iconfont图标字体库详细介绍

2024-09-04 10:44

本文主要是介绍iconfont图标字体库详细介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述

图标库在前端开发中应用十分广泛,图标库不仅会丰富美化界面的展示,语义化的图标库更能简洁明了地向用户传达某些信息,比如功能的特性和作用,引导用户,极大提高系统的易用性。在没有 UI 设计师的情况下,作为开发也可以自己打造图标库。而iconfont就是一种很好的选择。

iconfont

iconfont 介绍

iconfont是一个图标字体库,它允许用户将各种图标作为字体进行使用,十分方便地在网页和应用中展示图标。

iconfont 的特点
  • 图标字体:将图标作为字体使用,便于调整大小、颜色和样式,且不失真。
  • 自定义:用户可以上传自定义图标,生成自己的图标库。
  • SVG 支持:提供 SVG 格式图标,支持更高质量的图标显示。
  • 跨平台:兼容多种平台和浏览器,确保图标显示一致。
  • 便捷集成:通过 CSS 或 JavaScript 引入图标,简单易用

iconfont 使用步骤

iconfont的使用和管理也十分方便,使用前提是需要在其官方网站:iconfont 网站上注册一个账号并登录。主要步骤分为 1.制作图标字体库 2.使用图标字体库。

制作图标库

制作图标库过程如下

  • 打开网站 ——> 资源管理,先建一个项目,比如我的项目名称叫做 openlayers
    在这里插入图片描述
    在这里插入图片描述

  • 可以直接上传本地图片作为图标,也可以去进行搜索,比如搜索 CO2
    在这里插入图片描述

  • 在搜索结果页面,将想要的图标 添加到购物车

在这里插入图片描述
在这里插入图片描述

  • 这样就可以在 openlayers 项目看到港添加的新图标

在这里插入图片描述

使用图标库

iconfont的图标可以单个使用,也可以批量应用到项目中。批量应用又分三种方式:1.unicode 引用 2.font-class 引用 3.symbol 引用。这里以第三种方式为例。

使用前,从上面最后一张中可以看出,通过切换三种方式,在不同的方式下每个图标的名字都不一样,我们根据需要可以编辑每个图标的名称或者className
使用时,需要下载文件到本地,并在项目中引入即可。
在这里插入图片描述

使用步骤如下:

  • 引入下载文件中的iconfont.js文件
  • 设置 svg 的样式
.icon {width: 1em;height: 1em;vertical-align: -0.15em;fill: currentColor;overflow: hidden;
}
  • 在 html 中写如下代码
<svg class="icon svg-icon" aria-hidden="true"><use xlink:href="#icon-a-tree"></use>
</svg>
效果如下

在这里插入图片描述

iconfont 的原理

上面采用的第三种方式,和字体编码关系不大。引入的iconfont.js中代码比较好理解,主要就干了两件事 1.定义全局变量window._iconfont_svg_string_xxxxxx,该变量是一串 svg 代码,包含项目中每个图标的symbol 2.使用IIFE的模式将该 svg 字符串插入到 DOM 中去。

在这里插入图片描述

核心代码如下:

((e) => {var t = (a = (a = document.getElementsByTagName("script"))[a.length - 1]).getAttribute("data-injectcss"),a = a.getAttribute("data-disable-injectsvg");if (!a) {var l,i,c,n,o,h = function (t, a) {a.parentNode.insertBefore(t, a);};if (t && !e.__iconfont__svg__cssinject__) {e.__iconfont__svg__cssinject__ = !0;try {document.write("<style>.svgfont {display: inline-block;width: 1em;height: 1em;fill: currentColor;vertical-align: -0.1em;font-size:16px;}</style>");} catch (t) {console && console.log(t);}}(l = function () {var t,a = document.createElement("div");(a.innerHTML = e._iconfont_svg_string_4550938),(a = a.getElementsByTagName("svg")[0]) &&(a.setAttribute("aria-hidden", "true"),(a.style.position = "absolute"),(a.style.width = 0),(a.style.height = 0),(a.style.overflow = "hidden"),(a = a),(t = document.body).firstChild? h(a, t.firstChild): t.appendChild(a));}),document.addEventListener? ~["complete", "loaded", "interactive"].indexOf(document.readyState)? setTimeout(l, 0): ((i = function () {document.removeEventListener("DOMContentLoaded", i, !1), l();}),document.addEventListener("DOMContentLoaded", i, !1)): document.attachEvent &&((c = l),(n = e.document),(o = !1),s(),(n.onreadystatechange = function () {"complete" == n.readyState && ((n.onreadystatechange = null), d());}));}function d() {o || ((o = !0), c());}function s() {try {n.documentElement.doScroll("left");} catch (t) {return void setTimeout(s, 50);}d();}
})(window);

这篇关于iconfont图标字体库详细介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1135802

相关文章

Logback在SpringBoot中的详细配置教程

《Logback在SpringBoot中的详细配置教程》SpringBoot默认会加载classpath下的logback-spring.xml(推荐)或logback.xml作为Logback的配置... 目录1. Logback 配置文件2. 基础配置示例3. 关键配置项说明Appender(日志输出器

JSR-107缓存规范介绍

《JSR-107缓存规范介绍》JSR是JavaSpecificationRequests的缩写,意思是Java规范提案,下面给大家介绍JSR-107缓存规范的相关知识,感兴趣的朋友一起看看吧... 目录1.什么是jsR-1072.应用调用缓存图示3.JSR-107规范使用4.Spring 缓存机制缓存是每一

Java内存区域与内存溢出异常的详细探讨

《Java内存区域与内存溢出异常的详细探讨》:本文主要介绍Java内存区域与内存溢出异常的相关资料,分析异常原因并提供解决策略,如参数调整、代码优化等,帮助开发者排查内存问题,需要的朋友可以参考下... 目录一、引言二、Java 运行时数据区域(一)程序计数器(二)Java 虚拟机栈(三)本地方法栈(四)J

spring security 超详细使用教程及如何接入springboot、前后端分离

《springsecurity超详细使用教程及如何接入springboot、前后端分离》SpringSecurity是一个强大且可扩展的框架,用于保护Java应用程序,尤其是基于Spring的应用... 目录1、准备工作1.1 引入依赖1.2 用户认证的配置1.3 基本的配置1.4 常用配置2、加密1. 密

WinForms中主要控件的详细使用教程

《WinForms中主要控件的详细使用教程》WinForms(WindowsForms)是Microsoft提供的用于构建Windows桌面应用程序的框架,它提供了丰富的控件集合,可以满足各种UI设计... 目录一、基础控件1. Button (按钮)2. Label (标签)3. TextBox (文本框

Spring Boot 集成 Solr 的详细示例

《SpringBoot集成Solr的详细示例》:本文主要介绍SpringBoot集成Solr的详细示例,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录环境准备添加依赖配置 Solr 连接定义实体类编写 Repository 接口创建 Service 与 Controller示例运行

自研四振子全向增益天线! 中兴问天BE6800Pro+路由器拆机和详细评测

《自研四振子全向增益天线!中兴问天BE6800Pro+路由器拆机和详细评测》中兴问天BE6800Pro+路由器已经上市,新品配备自研四振子全向增益天线,售价399元,国补到手339.15元,下面我们... 中兴问天BE6800Pro+路由器自上市以来,凭借其“旗舰性能,中端价格”的定位,以及搭载三颗自研芯片

ubuntu20.0.4系统中安装Anaconda的超详细图文教程

《ubuntu20.0.4系统中安装Anaconda的超详细图文教程》:本文主要介绍了在Ubuntu系统中如何下载和安装Anaconda,提供了两种方法,详细内容请阅读本文,希望能对你有所帮助... 本文介绍了在Ubuntu系统中如何下载和安装Anaconda。提供了两种方法,包括通过网页手动下载和使用wg

SpringBoot实现二维码生成的详细步骤与完整代码

《SpringBoot实现二维码生成的详细步骤与完整代码》如今,二维码的应用场景非常广泛,从支付到信息分享,二维码都扮演着重要角色,SpringBoot是一个非常流行的Java基于Spring框架的微... 目录一、环境搭建二、创建 Spring Boot 项目三、引入二维码生成依赖四、编写二维码生成代码五

Java中 instanceof 的用法详细介绍

《Java中instanceof的用法详细介绍》在Java中,instanceof是一个二元运算符(类型比较操作符),用于检查一个对象是否是某个特定类、接口的实例,或者是否是其子类的实例,这篇文章... 目录引言基本语法基本作用1. 检查对象是否是指定类的实例2. 检查对象是否是子类的实例3. 检查对象是否