角コンポーネントへのローディングコンポーネントの追加
導入
Angular ウェブ、モバイル、デスクトップアプリケーションを構築するための開発プラットフォームです.現在、角度はバージョン13です、そして、Googleはプロジェクトの主な管理者です.
ngx-spinner 50以上の異なるタイプのローディング(スピナー)コンポーネントライブラリです.
必要条件
起動する前に、ツールをインストールして設定する必要があります.
始める
角度アプリケーションの作成
1 .角度ベース構造を使用したアプリケーションの作成
@angular/cli
ルートファイルとSCSSスタイル形式で.ng new angular-spinner
? Would you like to add Angular routing? Yes
? Which stylesheet format would you like to use? SCSS [ https://sass-lang.com/documentation/syntax#scss ]
CREATE angular-spinner/README.md (1060 bytes)
CREATE angular-spinner/.editorconfig (274 bytes)
CREATE angular-spinner/.gitignore (604 bytes)
CREATE angular-spinner/angular.json (3261 bytes)
CREATE angular-spinner/package.json (1077 bytes)
CREATE angular-spinner/tsconfig.json (783 bytes)
CREATE angular-spinner/.browserslistrc (703 bytes)
CREATE angular-spinner/karma.conf.js (1432 bytes)
CREATE angular-spinner/tsconfig.app.json (287 bytes)
CREATE angular-spinner/tsconfig.spec.json (333 bytes)
CREATE angular-spinner/src/favicon.ico (948 bytes)
CREATE angular-spinner/src/index.html (300 bytes)
CREATE angular-spinner/src/main.ts (372 bytes)
CREATE angular-spinner/src/polyfills.ts (2820 bytes)
CREATE angular-spinner/src/styles.scss (80 bytes)
CREATE angular-spinner/src/test.ts (788 bytes)
CREATE angular-spinner/src/assets/.gitkeep (0 bytes)
CREATE angular-spinner/src/environments/environment.prod.ts (51 bytes)
CREATE angular-spinner/src/environments/environment.ts (658 bytes)
CREATE angular-spinner/src/app/app-routing.module.ts (245 bytes)
CREATE angular-spinner/src/app/app.module.ts (393 bytes)
CREATE angular-spinner/src/app/app.component.scss (0 bytes)
CREATE angular-spinner/src/app/app.component.html (24617 bytes)
CREATE angular-spinner/src/app/app.component.spec.ts (1100 bytes)
CREATE angular-spinner/src/app/app.component.ts (220 bytes)
✔ Packages installed successfully.
2 .ブートストラップCSSフレームワークのインストールと設定.ポストのステップ2と3をしてください.インストール
ngx-spinner
図書館.npm install ngx-spinner
インポートBrowserAnimationsModule
, FormsModule
and NgxSpinnerModule
モジュールログ設定を構成します.変更するapp.module.ts
ファイルを追加し、以下の行を追加します.import { FormsModule } from '@angular/forms';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { NgxSpinnerModule } from 'ngx-spinner';
imports: [
BrowserModule,
BrowserAnimationsModule,
FormsModule,
NgxSpinnerModule,
AppRoutingModule,
],
5 .コンテンツの削除AppComponent
からのクラスsrc/app/app.component.ts
ファイル.インポートNgxSpinnerService
サービスと作成showSpinner
以下の方法.import { Component } from '@angular/core';
import { NgxSpinnerService } from 'ngx-spinner';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.scss'],
})
export class AppComponent {
typeSelected: string;
constructor(private spinnerService: NgxSpinnerService) {
this.typeSelected = 'ball-fussion';
}
public showSpinner(): void {
this.spinnerService.show();
setTimeout(() => {
this.spinnerService.hide();
}, 5000); // 5 seconds
}
}
6 .内容を削除するsrc/app/app.component.html
ファイル.追加するngx-spinner
コンポーネントとスピナーのオプションは以下の通りです.<div class="container-fluid py-3">
<h1>Angular Spinner</h1>
<div class="d-grid gap-2 col-4 mt-4 mx-auto">
<select name="type" #type="ngModel" [(ngModel)]="typeSelected" required [class.is-invalid]="type.invalid && (type.dirty || type.touched)" class="form-select form-select-sm">
<option value="ball-8bits">Ball 8bits</option>
<option value="ball-atom">Ball Atom</option>
<option value="ball-beat">Ball Beat</option>
<option value="ball-circus">Ball Circus</option>
<option value="ball-climbing-dot">Ball Climbing Dot</option>
<option value="ball-clip-rotate">Ball Clip Rotate</option>
<option value="ball-clip-rotate-multiple">Ball Clip Rotate Multiple</option>
<option value="ball-clip-rotate-pulse">Ball Clip Rotate Pulse</option>
<option value="ball-elastic-dots">Ball Elastic Dots</option>
<option value="ball-fall">Ball Fall</option>
<option value="ball-fussion">Ball Fussion</option>
<option value="ball-grid-beat">Ball Grid Beat</option>
<option value="ball-grid-pulse">Ball Grid Pulse</option>
<option value="ball-newton-cradle">Ball Newton Cradle</option>
<option value="ball-pulse">Ball Pulse</option>
<option value="ball-pulse-rise">Ball Pulse Rise</option>
<option value="ball-pulse-sync">Ball Pulse Sync</option>
<option value="ball-rotate">Ball Rotate</option>
<option value="ball-running-dots">Ball Running Dots</option>
<option value="ball-scale">Ball Scale</option>
<option value="ball-scale-multiple">Ball Scale Multiple</option>
<option value="ball-scale-pulse">Ball Scale Pulse</option>
<option value="ball-scale-ripple">Ball Scale Ripple</option>
<option value="ball-scale-ripple-multiple">Ball Scale Ripple Multiple</option>
<option value="ball-spin">Ball Spin</option>
<option value="ball-spin-clockwise">Ball Spin Clockwise</option>
<option value="ball-spin-clockwise-fade">Ball Spin Clockwise Fade</option>
<option value="ball-spin-clockwise-fade-rotating">Ball Spin Clockwise Fade Rotating</option>
<option value="ball-spin-fade">Ball Spin Fade</option>
<option value="ball-spin-fade-rotating">Ball Spin Fade Rotating</option>
<option value="ball-spin-rotate">Ball Spin Rotate</option>
<option value="ball-square-clockwise-spin">Ball Square Clockwise Spin</option>
<option value="ball-square-spin">Ball Square Spin</option>
<option value="ball-triangle-path">Ball Triangle Path</option>
<option value="ball-zig-zag">Ball Zig Zag</option>
<option value="ball-zig-zag-deflect">Ball Zig Zag Deflect</option>
<option value="cog">Cog</option>
<option value="cube-transition">Cube Transition</option>
<option value="fire">Fire</option>
<option value="line-scale">Line Scale</option>
<option value="line-scale-party">Line Scale Party</option>
<option value="line-scale-pulse-out">Line Scale Pulse Out</option>
<option value="line-scale-pulse-out-rapid">Line Scale Pulse Out Rapid</option>
<option value="line-spin-clockwise-fade">Line Spin Clockwise Fade</option>
<option value="line-spin-clockwise-fade-rotating">Line Spin Clockwise Fade Rotating</option>
<option value="line-spin-fade">Line Spin Fade</option>
<option value="line-spin-fade-rotating">Line Spin Fade Rotating</option>
<option value="pacman">Pacman</option>
<option value="square-jelly-box">Square Jelly Box</option>
<option value="square-loader">Square Loader</option>
<option value="square-spin">Square Spin</option>
<option value="timer">Timer</option>
<option value="triangle-skew-spin">Triangle Skew Spin</option>
</select>
<div *ngIf="type.invalid && (type.dirty || type.touched)" class="invalid-feedback">
<div *ngIf="type.errors?.required">This field is required.</div>
</div>
<button type="button" class="btn btn-sm btn-primary" (click)="showSpinner()">Show Spinner</button>
</div>
</div>
<ngx-spinner size="medium" [type]="typeSelected"></ngx-spinner>
7 .下記のコマンドでアプリケーションを実行します.npm start
> [email protected] start
> ng serve
✔ Browser application bundle generation complete.
Initial Chunk Files | Names | Size
vendor.js | vendor | 2.79 MB
styles.css | styles | 266.58 kB
polyfills.js | polyfills | 128.51 kB
scripts.js | scripts | 76.67 kB
main.js | main | 11.04 kB
runtime.js | runtime | 6.63 kB
| Initial Total | 3.27 MB
Build at: 2021-09-07T01:43:42.126Z - Hash: 52e507be2073bee125a1 - Time: 5289ms
** Angular Live Development Server is listening on localhost:4200, open your browser on http://localhost:4200/ **
✔ Compiled successfully.
8 .準備完了!URLにアクセスするhttp://localhost:4200/
そして、アプリケーションが動作しているかどうかを確認します.アプリケーションの作業GitHub Pages and Stackblitz .アプリケーションリポジトリはhttps://github.com/rodrigokamada/angular-spinner .
このチュートリアルはblog ポルトガル語.
Reference
この問題について(角コンポーネントへのローディングコンポーネントの追加), 我々は、より多くの情報をここで見つけました https://dev.to/rodrigokamada/adding-the-loading-component-spinner-to-an-angular-application-4mk0テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol