Angular 2测试使用async管道的可观察对象的加载指示器
创始人
2024-10-15 16:31:24
0

以下是一个使用async管道和可观察对象的加载指示器的示例代码:

  1. 创建一个名为isLoading的布尔变量,用于追踪数据是否正在加载。

  2. 在组件中定义一个data$的可观察对象,用于获取数据。

  3. 在模板中,使用async管道将可观察对象绑定到HTML元素上,并使用*ngIf指令根据isLoading的值显示或隐藏加载指示器。

组件代码示例:

import { Component } from '@angular/core';
import { Observable } from 'rxjs';
import { DataService } from './data.service';

@Component({
  selector: 'app-root',
  template: `
    
{{ data }}
Loading...
`, }) export class AppComponent { isLoading = false; data$: Observable; constructor(private dataService: DataService) {} ngOnInit() { this.isLoading = true; this.data$ = this.dataService.getData().pipe( finalize(() => { this.isLoading = false; }) ); } }

数据服务示例代码:

import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';

@Injectable({
  providedIn: 'root'
})
export class DataService {
  constructor(private http: HttpClient) {}

  getData() {
    return this.http.get('https://api.example.com/data');
  }
}

在这个示例中,当组件初始化时,isLoading变量被设置为true,加载指示器将显示出来。然后,通过数据服务获取数据,并将isLoading变量在可观察对象的finalize操作符中设置为false,以确保数据加载完成后加载指示器被隐藏。

相关内容

热门资讯

透视详细!德州透视插件(透视)... 透视详细!德州透视插件(透视)hh poker软件,教程策略(存在有挂)-哔哩哔哩在进入德州透视插件...
透视辅助!sohoo poke... 透视辅助!sohoo poker辅助(透视)wepoker怎么提高运气,教程学习(有挂解密)-哔哩哔...
透视科普!hhpoker有透视... 透视科普!hhpoker有透视功能吗(透视)hhpoker德州真的假的,教程诀窍(了解有挂)-哔哩哔...
透视揭露!pokerrrr2辅... 透视揭露!pokerrrr2辅助(透视)wepoker辅助透视软件,教程资料(有挂攻略)-哔哩哔哩1...
透视教你!智星德州插件怎么下载... 透视教你!智星德州插件怎么下载(透视)aapoker脚本,教程手册(有挂攻略)-哔哩哔哩1、智星德州...
透视解密!约局吧辅助器(透视)... 透视解密!约局吧辅助器(透视)pokemmo内置修改器,教程指南书(真是有挂)-哔哩哔哩1、poke...
透视推荐!福建大菠萝万能辅助器... 透视推荐!福建大菠萝万能辅助器(透视)wepokerplus到底是挂了吗,教程模块(有挂技术)-哔哩...
透视解迷!uupoker有透视... 透视解迷!uupoker有透视吗(透视)德普之星透视,教程妙招(有挂教学)-哔哩哔哩1、透视解迷!u...
透视开挂!wepokerplu... 透视开挂!wepokerplus透视脚本免费(透视)德普辅助软件,教程手册(真实有挂)-哔哩哔哩1、...
透视解谜!德普之星辅助器app... 透视解谜!德普之星辅助器app(透视)拱趴大菠萝开挂方法,教程技法(证实有挂)-哔哩哔哩1)拱趴大菠...