前言
本文主要给大家介绍了关于以Angular的姿势打开Font-Awesome的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。
环境
无须再用传统的 Web Font 方式
以前习惯于 Font-Awesome 的传统方式:页面底部引用一个 font-awesome.min.css 文件,然后在页面中使用 <i class="fa xxx"></i>
放置图标——这在 Angular 里依然可行,不过这并不 Angularish ——我们其实可以用 Angular 模块组件那种方式去实现。写此文时,官网还没有正式上线 Package for Angular, 不过在官方 GitHub 上已经有相关文档教程了,本文以下内容基本遵循该官方文档。
安装 Package
npm 方式:
$ npm install @fortawesome/fontawesome-svg-core --save$ npm install @fortawesome/free-solid-svg-icons --save$ npm install @fortawesome/angular-fontawesome --save
其中「free-solid-svg-icons」是经典样式,其他还有「regular」和「light」可选:
$ npm install @fortawesome/free-brands-svg-icons --save$ npm install @fortawesome/free-regular-svg-icons --save
在 app.module.ts 中导入基本模块
// ...import { FontAwesomeModule } from '@fortawesome/angular-fontawesome';@NgModule({ // ... imports: [ // ... FontAwesomeModule ], // ...})// ...
导入后便无须在其他组件中重复导入了。这是以下使用图标方式的基础。
按需使用方式一
在 component 里导入你所需要的图标:
// ...import { faCoffee } from '@fortawesome/free-solid-svg-icons';//...export class AppComponent { //... myIcon = faCoffee;}
注意:这里导入的图标名字要加 fa 前缀,并使用 camelCase 命名法。导入后,你便可以在 html 模板中用以下方式使用图标:
<fa-icon [icon]="myIcon"></fa-icon>
注意在 html 模板中要直接使用图标名。图标可在官网图标库查询。
按需使用方式二
第二种按需使用的方式是使用 library, 使用 library 后你就不用再在 component 中导入图标了,一切都在 app.module.ts 中完成:
import { FontAwesomeModule } from '@fortawesome/angular-fontawesome';import { library } from '@fortawesome/fontawesome-svg-core';
有了 library 后,接着再添加你需要用的图标:
import { FontAwesomeModule } from '@fortawesome/angular-fontawesome';import { library } from '@fortawesome/fontawesome-svg-core';import { faCoffee } from '@fortawesome/free-solid-svg-icons';
然后把图标加入到 library 里:
// import ...library.add(faCoffee);// NgModule({...
新闻热点
疑难解答
图片精选