Angular 5 - 提交时从一个组件传递数据到另一个组件
创始人
2024-10-15 21:00:46
0

要在Angular 5中从一个组件传递数据到另一个组件,可以使用以下方法:

  1. 使用@Input和@Output装饰器: 在要传递数据的源组件中,使用@Output装饰器创建一个事件,并在需要接收数据的目标组件中使用@Input装饰器来接收数据。

在源组件中:

import { Component, Output, EventEmitter } from '@angular/core';

@Component({
  selector: 'source-component',
  template: `
    
  `
})
export class SourceComponent {
  @Output() dataEvent = new EventEmitter();

  sendData() {
    const data = '要传递的数据';
    this.dataEvent.emit(data);
  }
}

在目标组件中:

import { Component, Input } from '@angular/core';

@Component({
  selector: 'target-component',
  template: `
    
接收到的数据:{{ receivedData }}
` }) export class TargetComponent { @Input() receivedData: string; }

在父组件中使用这两个组件:



在父组件的typescript文件中,定义一个变量来接收数据:

import { Component } from '@angular/core';

@Component({
  selector: 'app-parent-component',
  template: `
    
    
  `
})
export class ParentComponent {
  data: string;

  receiveData(data: string) {
    this.data = data;
  }
}
  1. 使用共享服务: 创建一个共享服务,可以在多个组件之间共享数据。在源组件中将数据存储在共享服务中,然后在目标组件中获取数据。

共享服务:

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

@Injectable()
export class DataService {
  private data: string;

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

  getData(): string {
    return this.data;
  }
}

在源组件中注入共享服务,并将数据存储在共享服务中:

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

@Component({
  selector: 'source-component',
  template: `
    
  `
})
export class SourceComponent {
  constructor(private dataService: DataService) {}

  sendData() {
    const data = '要传递的数据';
    this.dataService.setData(data);
  }
}

在目标组件中注入共享服务,并获取数据:

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

@Component({
  selector: 'target-component',
  template: `
    
接收到的数据:{{ receivedData }}
` }) export class TargetComponent { receivedData: string; constructor(private dataService: DataService) {} ngOnInit() { this.receivedData = this.dataService.getData(); } }

在父组件的模板中使用这两个组件:



在父组件的typescript文件中,将共享服务添加到providers中:

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

@Component({
  selector: 'app-parent-component',
  template: `
    
    
  `,
  providers: [DataService]
})
export class ParentComponent {}

这些方法可以根据你的具体需求选择使用。

相关内容

热门资讯

第五分钟方针!wepoker正... 第五分钟方针!wepoker正确养号方法(透视)确实存在有辅助透视(哔哩哔哩)1、wepoker正确...
9分钟指引!黑侠破解wepok... 9分钟指引!黑侠破解wepoker(透视)一贯真的是有辅助脚本(哔哩哔哩)黑侠破解wepoker辅助...
六分钟教材!hhpoker是内... 六分钟教材!hhpoker是内部控制吗(透视)确实存在有辅助工具(哔哩哔哩)1、玩家可以在hhpok...
四分钟手册!we poker游... 四分钟手册!we poker游戏下(透视)确实是真的有辅助教程(哔哩哔哩)1)we poker游戏下...
第5分钟大纲!hardrock... 第5分钟大纲!hardrock作必弊(透视)一贯存在有辅助安装(哔哩哔哩)1、hardrock作必弊...
1分钟窍门!wepokerpl... 1分钟窍门!wepokerplus脚本(透视)都是真的有辅助辅助(哔哩哔哩)1、操作简单,无需wep...
第二分钟练习!德普之星app安... 第二分钟练习!德普之星app安卓版破解版(透视)原来是有辅助教程(哔哩哔哩)进入游戏-大厅左侧-新手...
第五分钟妙计!wepoker科... 第五分钟妙计!wepoker科技辅助器(透视)确实有辅助神器(哔哩哔哩)1、进入游戏-大厅左侧-新手...
7分钟模板!德州私人局怎么透视... 7分钟模板!德州私人局怎么透视(透视)都是真的是有辅助下载(哔哩哔哩)德州私人局怎么透视脚本下载中分...
第四分钟学习!hhpoker作... 第四分钟学习!hhpoker作必弊实战视频(透视)本来真的是有辅助下载(哔哩哔哩)1、金币登录送、破...