Angular - 使用由回调函数设置的服务属性在另一个组件中使用
创始人
2024-10-14 22:30:44
0

要在一个组件中使用由回调函数设置的服务属性,你可以通过以下步骤实现:

  1. 首先,创建一个名为data.service.ts的服务文件并定义一个属性和一个回调函数:
import { Injectable } from '@angular/core';

@Injectable({
  providedIn: 'root'
})
export class DataService {
  private data: string;
  private callback: (data: string) => void;

  setData(data: string) {
    this.data = data;
    if (this.callback) {
      this.callback(data);
    }
  }

  registerCallback(callback: (data: string) => void) {
    this.callback = callback;
  }
}
  1. 然后,创建一个名为component1.component.ts的组件文件,在该组件中注册回调函数并使用服务属性:
import { Component, OnInit } from '@angular/core';
import { DataService } from '../data.service';

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

Component 1

`, }) export class Component1Component implements OnInit { constructor(private dataService: DataService) {} ngOnInit() {} setData() { this.dataService.setData('Hello from Component 1'); } }
  1. 接下来,创建一个名为component2.component.ts的组件文件,在该组件中订阅服务属性的变化:
import { Component, OnInit } from '@angular/core';
import { DataService } from '../data.service';

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

Component 2

Data: {{ data }}

`, }) export class Component2Component implements OnInit { data: string; constructor(private dataService: DataService) {} ngOnInit() { this.dataService.registerCallback(this.updateData.bind(this)); } updateData(data: string) { this.data = data; } }
  1. 最后,将这两个组件添加到你的模块中:
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';

import { AppComponent } from './app.component';
import { Component1Component } from './component1.component';
import { Component2Component } from './component2.component';
import { DataService } from './data.service';

@NgModule({
  declarations: [AppComponent, Component1Component, Component2Component],
  imports: [BrowserModule],
  providers: [DataService],
  bootstrap: [AppComponent],
})
export class AppModule {}

现在,当你在Component1Component中点击按钮时,服务属性将被更新,并且Component2Component中的数据也会相应更新。

相关内容

热门资讯

两分钟辅助!wpk安卓下载辅助... 两分钟辅助!wpk安卓下载辅助,wepokerplus辅助,妙计教程(有挂详细)1、wpk安卓下载辅...
七分钟辅助!werplan透视... 七分钟辅助!werplan透视挂,sohoopoker辅助,机巧教程(有挂攻略)werplan透视挂...
一分钟辅助!wpk俱乐部怎么作... 一分钟辅助!wpk俱乐部怎么作弊,拱趴大菠萝十三水作弊,指引教程(真是有挂)小薇(辅助器软件下载)致...
第7分钟辅助!wepoker免... 第7分钟辅助!wepoker免费透视脚本,hhpoker外挂靠谱吗,手筋教程(有挂细节)1、超多福利...
一分钟辅助!wpk辅助,约局吧... 一分钟辅助!wpk辅助,约局吧德州可以透视吗,烘培教程(真的有挂)1、实时约局吧德州可以透视吗透视辅...
第9分钟辅助!pokemomo... 第9分钟辅助!pokemomo辅助软件,wepoker轻量版透视方法,大纲教程(有挂攻略)1)wep...
第9分钟辅助!wepokerp... 第9分钟辅助!wepokerplus辅助,pokemmo脚本辅助下载,妙招教程(真实有挂)该软件可以...
7分钟辅助!wepoker究竟... 7分钟辅助!wepoker究竟有没有透视,菠萝德普辅助器免费版在哪里,窍要教程(真实有挂)1、菠萝德...
六分钟辅助!hhpoker辅助... 六分钟辅助!hhpoker辅助软件下载,wpk辅助,妙招教程(有挂秘籍)运hhpoker辅助软件下载...
五分钟辅助!来玩app破解,a... 五分钟辅助!来玩app破解,aapoker ai插件,举措教程(有挂讲解)1、aapoker ai插...