是伍尚金哇_v

angular使用加载指示符loading的ngx-loading

电脑版发表于:2020/12/23 18:18

前言

欢迎使用tnblog

如果你的项目是纯angular需要用到请求或者其他方式时在在界面上通过loading的方式来展示请求进度或其他;
这里我使用ngx-loading,源码:https://github.com/Zak-C/ngx-loading

终端运行命令:

npm install --save ngx-loading


导入NgxLoadingModule模块:app.module.ts

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';

import { AppRoutingModule } from './app-routing.module';
import { AppComponent } from './app.component';

import { NgxLoadingModule } from 'ngx-loading';

@NgModule({
  declarations: [
    AppComponent
  ],
  imports: [
    BrowserModule,
    AppRoutingModule,
    NgxLoadingModule
  ],
  providers: [],
  bootstrap: [AppComponent]
})
export class AppModule { }


TS后台代码:app.component.ts

import { ComponentOnInitTemplateRefViewChild } from '@angular/core';
import { DomSanitizer } from '@angular/platform-browser';
import { ngxLoadingAnimationTypesNgxLoadingComponent } from 'ngx-loading';

const PrimaryWhite = '#ffffff';
const SecondaryGrey = '#ccc';
const PrimaryRed = '#dd0031';
const SecondaryBlue = '#006ddd';

@Component({
  selector: 'app-test-page2',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.less']
})
export class TestPage2Component implements OnInit {

  @ViewChild('ngxLoading', { static: false }) ngxLoadingComponentNgxLoadingComponent;
  @ViewChild('customLoadingTemplate', { static: false }) customLoadingTemplateTemplateRef<any>;
  public ngxLoadingAnimationTypes = ngxLoadingAnimationTypes;
  public loading = true;
  public primaryColour = PrimaryWhite;
  public secondaryColour = SecondaryGrey;
  public coloursEnabled = false;
  public loadingTemplateTemplateRef<any>;
  public config = { animationType: ngxLoadingAnimationTypes.noneprimaryColour: this.primaryColoursecondaryColour: this.secondaryColourtertiaryColour: this.primaryColourbackdropBorderRadius: '3px' };

  constructor(private sanitizerDomSanitizer) { }

  public toggleColours(): void {
    this.coloursEnabled = !this.coloursEnabled;

    if (this.coloursEnabled) {
      this.primaryColour = PrimaryRed;
      this.secondaryColour = SecondaryBlue;
    } else {
      this.primaryColour = PrimaryWhite;
      this.secondaryColour = SecondaryGrey;
    }
  }

  toggleTemplate(): void {
    if (this.loadingTemplate) {
      this.loadingTemplate = null;
    } else {
      this.loadingTemplate = this.customLoadingTemplate;
    }
  }

  public showAlert(): void {
    alert('ngx-loading rocks!');
  }

  ngOnInit(): void {
  }

}


html界面代码:app.component.html

<div id="header">
    <img width="100" src="https://angular.cn/assets/images/logos/angular/angular.svg" alt="angular icon">
    <h1>ngx-loading</h1>
  </div>
  
  <button id="toggle-loading-button" (click)="loading = !loading">Toggle loading</button>
  <button id="toggle-colours-button" (click)="toggleColours()">Toggle colours</button>
  <button id="toggle-template-button" (click)="toggleTemplate()">Toggle template</button>
  
  <ng-template #customLoadingTemplate>
    <div class="custom-class">
      <h3>
        Loading...
      </h3>
      <button (click)="showAlert()">
        Click me!
      </button>
    </div>
  </ng-template>
  
  <div class="loading-container">
    <div class="loading">
      <h2>threeBounce</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
        magna aliqua.</p>
      <ngx-loading [show]="loading" [config]="{primaryColourprimaryColoursecondaryColoursecondaryColourtertiaryColourprimaryColourbackdropBorderRadius'3px'}"
        [template]="loadingTemplate"></ngx-loading>
    </div>
  
    <div class="loading">
      <h2>chasingDots</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
        magna aliqua.</p>
      <ngx-loading [show]="loading" [config]="{animationTypengxLoadingAnimationTypes.chasingDotsprimaryColourprimaryColoursecondaryColoursecondaryColourbackdropBorderRadius'3px'}"
        [template]="loadingTemplate"></ngx-loading>
    </div>
  
    <div class="loading">
      <h2>doubleBounce</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
        magna aliqua.</p>
      <ngx-loading [show]="loading" [config]="{animationTypengxLoadingAnimationTypes.doubleBounceprimaryColourprimaryColoursecondaryColoursecondaryColourbackdropBorderRadius'3px'}"
        [template]="loadingTemplate"></ngx-loading>
    </div>
  
    <div class="loading">
      <h2>circle</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
        magna aliqua.</p>
      <ngx-loading [show]="loading" [config]="{animationTypengxLoadingAnimationTypes.circleprimaryColourprimaryColoursecondaryColoursecondaryColourbackdropBorderRadius'3px'}"
        [template]="loadingTemplate"></ngx-loading>
    </div>
  
    <div class="loading">
      <h2>circleSwish</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
        magna aliqua.</p>
      <ngx-loading [show]="loading" [config]="{animationTypengxLoadingAnimationTypes.circleSwishprimaryColourprimaryColourbackdropBorderRadius'3px'}"
        [template]="loadingTemplate"></ngx-loading>
    </div>
  
    <div class="loading">
      <h2>cubeGrid</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
        magna aliqua.</p>
      <ngx-loading [show]="loading" [config]="{animationTypengxLoadingAnimationTypes.cubeGridprimaryColourprimaryColourbackdropBorderRadius'3px'}"
        [template]="loadingTemplate"></ngx-loading>
    </div>
  
    <div class="loading">
      <h2>pulse</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
        magna aliqua.</p>
      <ngx-loading [show]="loading" [config]="{animationTypengxLoadingAnimationTypes.pulseprimaryColourprimaryColoursecondaryColoursecondaryColourbackdropBorderRadius'3px'}"
        [template]="loadingTemplate"></ngx-loading>
    </div>
  
    <div class="loading">
      <h2>rectangleBounce</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
        magna aliqua.</p>
      <ngx-loading [show]="loading" [config]="{animationTypengxLoadingAnimationTypes.rectangleBounceprimaryColourprimaryColourbackdropBorderRadius'3px'}"
        [template]="loadingTemplate"></ngx-loading>
    </div>
  
    <div class="loading">
      <h2>rotatingPlane</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
        magna aliqua.</p>
      <ngx-loading [show]="loading" [config]="{animationTypengxLoadingAnimationTypes.rotatingPlaneprimaryColourprimaryColourbackdropBorderRadius'3px'}"
        [template]="loadingTemplate"></ngx-loading>
    </div>
  
    <div class="loading">
      <h2>wanderingCubes</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
        magna aliqua.</p>
      <ngx-loading [show]="loading" [config]="{animationTypengxLoadingAnimationTypes.wanderingCubesprimaryColourprimaryColoursecondaryColoursecondaryColourbackdropBorderRadius'3px'}"
        [template]="loadingTemplate"></ngx-loading>
    </div>
  
    <div class="loading">
      <h2>none</h2>
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
        magna aliqua.</p>
      <ngx-loading #ngxLoading [show]="loading" [config]="config" [template]="loadingTemplate"></ngx-loading>
    </div>
  </div>
  


写点样式渲染:app.component.less

#header {
    displayflex;
    flex-directioncolumn;
    align-itemscenter;
  }
  
  h1 {
    margin-top0;
  }
  
  .loading-container {
    displayflex;
    flex-wrapwrap;
  }
  
  .loading {
    height189px;
    width189px;
    positionrelative;
    margin0 15px 15px 0;
    padding15px;
    border1px #ccc solid;
    border-radius4px;
  }
  
  .loading p {
    margin0 0 10px 0;
  }
  
  button {
    bordernone;
    border-radius4px;
    padding6px;
    colorwhite;
    outlinenone;
    font-weightbold;
    font-size1.1em;
    margin15px 15px 15px 0;
    font-family'Roboto'sans-serif;
    cursorpointer;
    background-color#666666;
  }
  
  button:hover {
    background-color#797979;
  }
  
  button#toggle-loading-button {
    background-color#dd0031;
  }
  
  button#toggle-loading-button:hover {
    background-color#ff0032;
  }
  
  button#toggle-colours-button {
    background-color#006ddd;
  }
  
  button#toggle-colours-button:hover {
    background-color#0c7aea;
  }
  
  button#toggle-template-button {
    background-colorblack;
  }
  
  button#toggle-template-button:hover {
    background-color#303030;
  }
  
  .custom-class {
    top0;
    z-index2002;
    positionabsolute;
    left0;
    right0;
    bottom0;
    displayflex;
    flex-directioncolumn;
    justify-contentcenter;
    align-itemscenter;
    background-color#000000ba;
    border-radius3px;
  }
  
  .custom-class h3 {
    colorwhite;
  }
  


效果

关于TNBLOG
TNBLOG,技术分享
ICP备案 :渝ICP备18016597号-1
App store Android
精彩评论
{{item.replyName}}
{{item.content}}
{{item.time}}
{{subpj.replyName}}
@{{subpj.beReplyName}}{{subpj.content}}
{{subpj.time}}
猜你喜欢