1

堆栈:Angular 9.1.7、Nebular 5.0.0、FontAwesome 5.13

我想使用以下指南将 Nebular 使用的默认图标集 (EvaIcons) 更改为 FontAwesome:

https://akveo.github.io/nebular/docs/guides/register-icon-pack#register-icon-pack

不幸的是,图标没有显示出来。我很接近,因为星云 EvaIcon 不再显示。从 DeveloperTools 中,我可以看到nb-iconusing fa-user,但没有显示任何内容。

4

2 回答 2

9

您没有提供已安装或配置的内容。

但无论如何,我的答案来了……我已经将 FontAwesome 加载到我的 Nebular 应用程序中。也就是说,不是替换 EvaIcons,而是将它们另外添加到 Eva。

  1. 安装 FontAwesome。
  2. 将其包含在您的 angular.json 中
  3. 在 app.component 中注册图标包
  4. 在 Nebulas nb-icon 组件中使用 FontAwesome

在代码中:

1. npm install --save @fortawesome/fontawesome-free

2. "styles": [..., "node_modules/@fortawesome/fontawesome-free/css/all.css", ...],
   "scripts": [..., "node_modules/@fortawesome/fontawesome-free/js/all.js", ...]

3. import { NbIconLibraries } from '@nebular/theme';
   @Component({
     selector: 'ngx-app',
     template: '<router-outlet></router-outlet>',
   })
   export class AppComponent implements OnInit {
     constructor(private iconLibraries: NbIconLibraries) {
       this.iconLibraries.registerFontPack('fas', { packClass: 'fas', iconClassPrefix: 'fa' });
       this.iconLibraries.registerFontPack('far', { packClass: 'far', iconClassPrefix: 'fa' });
       this.iconLibraries.registerFontPack('fab', { packClass: 'fab', iconClassPrefix: 'fa' });
       this.iconLibraries.setDefaultPack('far');
   ...

4. <nb-icon icon="arrow-right" pack="fas"></nb-icon>

(Maybe there is a better way of doing this, maybe loading the js isn't required idk...)

这样您就可以使用 Eva 或 FontAwesome 图标,或任何注册包。

Eva:         <nb-icon icon="SOME_ICON">                           </nb-icon>
FontAwesome: <nb-icon icon="SOME_ICON" pack="fas/far/fab/fal/fad"></nb-icon>
于 2020-10-26T21:18:40.870 回答
1

使用下面的方法,

  1. 安装字体真棒
npm install --save @fortawesome/fontawesome-free
  1. 在 angular.json 文件中添加样式
"styles": [
     "node_modules/@fortawesome/fontawesome-free/css/all.css",
 ],
  1. 导入模块
import { NbIconModule } from '@nebular/theme';

imports: [
    NbIconModule,
],
  1. 在组件.ts
 constructor(private iconLibraries: NbIconLibraries) {
    this.iconLibraries.registerFontPack('font-awesome', { packClass: 'fab', iconClassPrefix: 'fa' });
  }
  1. 在 Component.html 中
<nb-icon icon="instagram" pack="font-awesome"></nb-icon>

我希望它会工作

于 2020-12-03T02:57:37.140 回答