Angular 8如何从其上下文之外访问数据并检测变化。
创始人
2024-10-17 22:01:15
0

在Angular中,可以使用服务(Service)来从其上下文之外访问数据并检测变化。下面是一个示例:

首先,创建一个数据服务(data.service.ts):

import { Injectable } from '@angular/core';
import { BehaviorSubject } from 'rxjs';

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

  constructor() { }

  updateData(newData: string) {
    this.dataSubject.next(newData);
  }
}

在上面的代码中,我们使用了BehaviorSubject来作为数据的容器,并将其暴露为data$的可观察对象。

然后,在需要访问数据的组件中,注入数据服务,并订阅数据的变化:

import { Component, OnInit } from '@angular/core';
import { DataService } from './data.service';

@Component({
  selector: 'app-my-component',
  template: `
    

{{ data }}

`, }) export class MyComponent implements OnInit { data: string; constructor(private dataService: DataService) { } ngOnInit() { this.dataService.data$.subscribe(newData => { this.data = newData; }); } updateData() { this.dataService.updateData('New data'); } }

在上面的代码中,我们注入了数据服务,并在ngOnInit生命周期钩子中订阅了数据的变化。每当数据发生变化时,回调函数会被触发,并更新组件中的数据。

最后,在组件的模板中,我们可以通过{{ data }}来显示数据,并通过点击按钮来更新数据。

这样,我们就可以从组件的上下文之外访问数据,并且当数据发生变化时,组件会自动检测到并更新视图。

相关内容

热门资讯

据报道!微乐小程序黑科技,苹果... 据报道!微乐小程序黑科技,苹果手机微信小程序游戏破解器(透视)一贯真的是有挂(哔哩哔哩)1、实时苹果...
六分钟开挂!微乐小程序免费黑科... 六分钟开挂!微乐小程序免费黑科技,微乐小程序辅助脚本靠谱的(开挂)其实是有挂(2026)1、微乐小程...
为切实保障!微乐小程序免费黑科... 为切实保障!微乐小程序免费黑科技,微乐家乡app下载(透视)一直真的有挂(哔哩哔哩)亲,关键说明,微...
8分钟透视!微乐小程序黑科技,... 8分钟透视!微乐小程序黑科技,微信微乐辅助器使用教程(开挂)其实真的有挂(2026)1、微乐小程序黑...
突发!微乐小程序免费黑科技,微... 突发!微乐小程序免费黑科技,微乐小程序辅助器免费(透视)都是存在有挂(哔哩哔哩)暗藏猫腻,小编详细说...
第2分钟神器!微乐小程序免费黑... 第2分钟神器!微乐小程序免费黑科技,微乐江苏小程序游戏破解下载(开挂)好像有挂(2026)1.微乐小...
透视安卓版!微乐小程序免费黑科... 透视安卓版!微乐小程序免费黑科技,微乐广西小程序插件(透视)总是真的是有挂(哔哩哔哩)1、操作简单,...
第3分钟神器!微乐小程序免费黑... 第3分钟神器!微乐小程序免费黑科技,微乐小程序脚本入口(开挂)一直真的是有挂(2026)微乐小程序免...
做出回应!微乐小程序免费黑科技... 做出回应!微乐小程序免费黑科技,微乐家乡辅助app免费(透视)总是有挂(哔哩哔哩)1、微乐小程序免费...
两分钟脚本!微乐小程序免费黑科... 两分钟脚本!微乐小程序免费黑科技,微乐小程序自建房辅助ios(开挂)竟然是有挂(2026)1)微乐小...