You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

为何Font-Awesome图标类名存在差异?

为何Font-Awesome图标类名存在差异?

嘿,这个问题问得很到位!Font Awesome图标类名的差异主要源于版本迭代的更新5.x版本起新增的图标分类机制,我给你详细拆解:

1. 核心原因:Font Awesome 4.x vs 5.x的版本差异

你代码里同时引入了Font Awesome 4.7.0的CSS和5.0.10的JS,这两个版本的类名规则完全不同:

  • 4.x版本:所有图标统一使用基础前缀 fa,类名结构是 fa fa-[图标名],比如你写的 <i class="fa fa-edit"></i> 就是4.x的标准写法。
  • 5.x版本:对图标系统做了重构,引入了分类前缀,类名结构变成 [分类前缀] fa-[图标名],这就是你看到fas fa-pencilfab fa-facebook的原因。

2. 5.x版本的分类前缀详解

5.x把图标按风格/类型分成了不同组别,每个组别对应专属前缀:

  • fas:Solid(实心风格)—— 最常用的实心图标,比如fas fa-pencil是实心铅笔图标
  • far:Regular(空心/常规风格)—— 空心线条风格的图标(部分需要Pro版本支持)
  • fab:Brands(品牌图标)—— 社交媒体、企业品牌类图标,比如fab fa-facebook就是Facebook的品牌图标
  • (Pro版本专属)fal:Light(轻量细线条风格)、fad:Duotone(双色风格)

小提醒:避免多版本冲突

你代码里同时加载了4.x和5.x的资源,这很容易导致样式冲突或图标显示异常。建议只保留一个版本的资源:

  • 如果用4.x:只保留<link href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.css" rel="stylesheet" />,所有图标用fa fa-[图标名]写法
  • 如果用5.x:只保留<script defer src="https://use.fontawesome.com/releases/v5.0.10/js/all.js" integrity="sha384-slN8GvtUJGnv6ca26v8EzVaR9DC58QEwsIk9q1QXdCU8Yu8ck/tL/5szYlBbqmS+" crossorigin="anonymous"></script>,图标对应使用fas/far/fab等前缀

内容的提问来源于stack exchange,提问作者Pranta Saha

火山引擎 最新活动