Angularのお勧めライブラリ12選!UIコンポーネント・グラフ・カレンダー。
この記事では、UIコンポーネントをはじめとするAngularのサードパーティー製ライブラリを12個ピックアップして紹介する。
既に業務でAngularを使用している人も現在ポートフォリオ作成のためのフレームワーク選びをしている人も参考になると思うので最後まで読んでいってほしい。
なお、ここで紹介しているライブラリはすべて著者が実際にテストしており、現在も定期的にメンテナンスされているライブラリをセレクトするようにした。
UIコンポーネント・ライブラリ
まずはライブラリの王道とも言えるUIコンポーネントのライブラリから紹介していきたい。
Angular Material
公式サイト:: https://material.angular.io
GitHub:: https://github.com/angular/components
Angular Materialはいわずと知れたAngularの公式マテリアルデザインライブラリ。
Angularを業務で使用するなら一度は使ってみておきたいライブラリだ。
ただし、マテリアルデザインは好みが分かれるうえにブームが過ぎた感じはあるので、もう少しニュートラルなデザインがほしいなら後に紹介するNGX Bootstrapを使ったほうがいいかもしれない。
Angular Materialについてもっと知りたい人はこちらの記事を読んでほしい。
- 公式ライブラリである安定性
- ドキュメントやネット上の情報が豊富
- 直感的な操作性でユーザーフレンドリー
- レスポンシブデザインに非対応
NGX Bootstrap
公式サイト:: https://valor-software.com/ngx-bootstrap
GitHub:: https://github.com/valor-software/ngx-bootstrap
NGX BootstrapはAngularプロジェクトにBootstrapを手軽に導入するためのライブラリ。
Bootstrapはこの章で紹介している他のUIライブラリとは異なり、独自のコンポーネントを追加するためのライブラリでは無く、HTML標準のコンポーネントにCSSクラスを追加することによって希望するデザインに整える。
また、Bootstrapのレスポンスデザイン対応は理解しやすく定評がある。
なお、Angularプロジェクトでbootstrapを使用するためのライブラリには「NG-Bootstrap」もあり、そちらは別のチームによって開発されている別のライブラリだ。
この記事ではアップデートが頻繁におこなわれているNGX-Bootstrapのほうをオススメしている。
- デザインに特化しているので簡単
- ヘルパークラスが豊富
- 直感的なレスポンシブ対応
Prime NG
公式サイト:: https://primefaces.org/primeng
GitHub:: https://github.com/primefaces/primeng
Prime NGはAngularのためのUIコンポーネントライブラリ。
JavaServerFacesのUIコンポーネントであるPrimefacesを手掛けたUI開発のエキスパートであるトルコのPrimeTek Informatics社が制作している。
Prime NGにはプロによって制作されたテンプレートが豊富に用意されており、プロダクトのイメージに合ったテンプレートを探すことができる。
基本的には無料のライブラリであり、個人で開発をするのであれば個人的に一番オススメするのはこのPrime NGだ。
- UIコンポーネント専門企業の信頼性
- 90種類以上のコンポーネント
- 要件に合わせてカスタマイズしやすい
- 定期的なアップデート
NG-ZORRO
公式サイト:: https://ng.ant.design
GitHub:: https://github.com/NG-ZORRO/ng-zorro-antd
NG-ZORROは中国のデベロッパーによって作られたUIコンポーネントライブラリ。
オンラインマーケットAlibabaで採用されているAnt Designシステムをベースに作られており、特に中国では人気があるコンポーネントライブラリだ。
スタンダードで使いやすいデザインとなっているが、今のとこと英語で書かれたドキュメントは充実していないようだ。
- TypeScriptで書かれたライブラリ
- 60種類以上のUIコンポーネント
- 軽量で高パフォーマンス
Kendo UI
公式サイト:: https://www.telerik.com/kendo-angular-ui
GitHub:: https://github.com/telerik/kendo-ui-core
Kendo UIはProgress Software社によって開発されているUIコンポーネントライブラリ。
100を超えるUIコンポーネントを備えており、あらゆる要望に応えられるような充実したライブラリ。
有料のライブラリではあるが、ある程度規模の大きいプロジェクトで、手早く高品質なUIが欲しいという場合は導入を検討してみてもいいだろう。
- 100を超えるUIコンポーネント
- コンポーネントはすぐにプロジェクト使用可能
- 高機能なスケジューラーコンポーネント
- 完全なネイティブコンポーネントで高パフォーマンス
IgniteUI
公式サイト:: https://www.infragistics.com
GitHub:: https://github.com/IgniteUI/igniteui-angular
IgniteUIはUI&UXツールキットを専門に開発するInfragistics社によって開発されたUIコンポーネントライブラリ。
Kendo UIと同様に有料のライブラリだが、クオリティ・デザインともに非常にレベルが高い印象だ。
コンポーネントがどういった業種・シチュエーションで使われるのかをよく考えて作られており、カスタマイズの必要無しにすぐ導入することができそうだ。
- 60種類以上の実用的で高品質なUIコンポーネント
- グラフ・チャートのコンポーネントに強い
- 業種ごとにカスタマイズされたデモプロジェクト
- モダンでクールなデザイン
その他、注目のライブラリ
Angularのエキスパートならば抑えておきたい注目のライブラリを紹介したい。
NgRx
公式サイト:: https://ngrx.io
GitHub:: https://github.com/ngrx/platform
NgRxはアプリの状態管理をおこなうためのライブラリ。
NgRxはReduxにインスピレーションを受け作成されたAngularのためのライブラリでRxJsを内部で使用している。
Angularでは状態管理をサービスに委ねることが多いがアプリの規模が大きくなると煩雑になりやすい。
NgRxは特に多くのユーザーインタラクションを必要とするアプリにおいては有効だ。
ngx-pipes
GitHub:: https://github.com/danrevah/ngx-pipes
ngx-pipesはAngularパイプを拡張するライブラリ。
Angularにはデフォルトで標準パイプが用意されているが、おこなう処理によっては足りないと感じる部分も多い。
ngx-pipesでは特にstringやarrayのための便利な関数が用意されている。
Angularの標準ライブラリである「i18n」よりも随分とシンプルで使いやすく、Angular開発者の間では定番となっている。
なお、i18nについて詳しく知りたい人はこちらの記事を参考にしてほしい。
ngx-translate
公式サイト:: http://www.ngx-translate.com
GitHub:: https://github.com/ngx-translate/core
ngx-translateはAngularのための国際化(翻訳)ライブラリ。
ngx-moment
GitHub:: https://github.com/urish/ngx-moment
ngx-momentはmoment.jsをAngularで使用するためのライブラリ。
moment.jsは日付や時間を変換・フォーマットする際に便利なユーティリティー関数を数多く含むライブラリ、JavaScript開発者の間では定番のライブラリとなっている。
AngularFire2
GitHub:: https://github.com/angular/angularfire
AngularFireはAngularの公式Firebaseライブラリ。
FirebaseをAngularアプリで使用する際にはよく使われる。
SPA(シングルページアプリケーション)ではプッシュ通知やPWA(Progressive Web App)といった技術がスタンダードに使われるようになってきているが、それらの技術を使用するためにFirebaseは欠かせなくなってきている。
msw Mock Service Worker
公式サイト:: https://mswjs.io
GitHub:: https://github.com/mswjs/msw
msw(Mock Service Worker)は疑似(モック)APIを使用するためのライブラリ。
テストや開発においてはアプリを起動しているものの、本物のバックエンドシステムと通信をおこなうことが出来ない場面は多々ある。
mswはそういった場面で疑似的なAPIを作り、リクエストに対する任意のレスポンスを送信することができる。
mswは特にKarmaやStorybookといったライブラリを使用している際に必要となることが多い。