角コンポーネントへのローディングコンポーネントの追加



導入
Angular ウェブ、モバイル、デスクトップアプリケーションを構築するための開発プラットフォームです.現在、角度はバージョン13です、そして、Googleはプロジェクトの主な管理者です.
ngx-spinner 50以上の異なるタイプのローディング(スピナー)コンポーネントライブラリです.

必要条件
起動する前に、ツールをインストールして設定する必要があります.
  • git
  • Node.js and npm
  • Angular CLI
  • IDE (例:Visual Studio Code )

  • 始める

    角度アプリケーションの作成
    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 ポルトガル語.