Angular的BehaviorSubject无法从http调用中获取数据。
创始人
2024-10-24 01:30:43
0

要在Angular的BehaviorSubject中获取从http调用中获取的数据,可以执行以下步骤:

  1. 创建一个名为data.service.ts的服务文件,并导入所需的Angular模块和操作符:
import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { BehaviorSubject } from 'rxjs';

@Injectable({
  providedIn: 'root'
})
export class DataService {
  private dataSubject = new BehaviorSubject(null);
  data$ = this.dataSubject.asObservable();

  constructor(private http: HttpClient) { }
}
  1. 在服务文件中,创建一个方法来执行http调用并将数据发送到BehaviorSubject:
import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { BehaviorSubject } from 'rxjs';

@Injectable({
  providedIn: 'root'
})
export class DataService {
  private dataSubject = new BehaviorSubject(null);
  data$ = this.dataSubject.asObservable();

  constructor(private http: HttpClient) { }

  fetchData() {
    this.http.get('your-api-url')
      .subscribe(data => {
        this.dataSubject.next(data);
      });
  }
}
  1. 在组件中注入数据服务,并订阅data$ Observable以获取数据更新:
import { Component, OnInit } from '@angular/core';
import { DataService } from 'data.service';

@Component({
  selector: 'app-your-component',
  templateUrl: './your-component.component.html',
  styleUrls: ['./your-component.component.css']
})
export class YourComponent implements OnInit {
  data: any;

  constructor(private dataService: DataService) { }

  ngOnInit() {
    this.dataService.data$.subscribe(data => {
      this.data = data;
    });
    this.dataService.fetchData();
  }
}

这样,当组件初始化时,它将订阅data$ Observable,并在数据服务的fetchData方法中执行http调用。一旦数据从http调用中获取并发送到BehaviorSubject,组件将接收到更新的数据并进行相应的操作。

相关内容

热门资讯

透视计算!微乐小程序免费黑科技... 透视计算!微乐小程序免费黑科技,微乐家乡麻辣自建房辅助app(透视)确实是真的挂(哔哩哔哩)1)微乐...
四分钟神器!微乐小程序免费黑科... 四分钟神器!微乐小程序免费黑科技,微信小程序微乐家乡辅助器(开挂)切实是真的挂(2026)1、上手简...
透视存在!微乐小程序黑科技,微... 透视存在!微乐小程序黑科技,微乐家乡脚本助手(透视)都是真的有挂(哔哩哔哩)1、进入到微乐家乡脚本助...
第7分钟教程!微乐小程序免费黑... 第7分钟教程!微乐小程序免费黑科技,微乐贵阳捉鸡麻将辅助(开挂)总是是有挂(2026)该软件可以轻松...
插件辅助挂!微乐小程序免费黑科... 插件辅助挂!微乐小程序免费黑科技,微乐小程序游戏破解器下载(透视)竟然真的有挂(哔哩哔哩)1、每一步...
第7分钟神器!微乐小程序免费黑... 您好,微乐小程序免费黑科技这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054】很...
透视游戏!微乐小程序免费黑科技... 透视游戏!微乐小程序免费黑科技,微乐小程游戏破解器下载(透视)其实真的是有挂(哔哩哔哩)1、上手简单...
六分钟教程!微乐小程序黑科技,... 六分钟教程!微乐小程序黑科技,微乐家乡官方app(开挂)其实是真的挂(2026)1、许多玩家不知道微...
2026版规律!微乐小程序免费... 2026版规律!微乐小程序免费黑科技,广西微乐小程序辅助器(透视)一贯存在有挂(哔哩哔哩)1、该软件...
3分钟辅助!微乐小程序免费黑科... 3分钟辅助!微乐小程序免费黑科技,微信小程序微乐安徽辅助器(开挂)都是真的有挂(2026)暗藏猫腻,...