Heim > Web-Frontend > js-Tutorial > Erfahren Sie mehr über @Input() und @Output() in Angular

Erfahren Sie mehr über @Input() und @Output() in Angular

青灯夜游
Freigeben: 2021-02-01 11:47:55
nach vorne
2974 Leute haben es durchsucht

Erfahren Sie mehr über @Input() und @Output() in Angular

Empfohlene verwandte Tutorials: angularjs (Video-Tutorial)

Das Erstellen einer Schülerklasse

hat nur ein paar einfache Attribute (führen Sie die folgenden Attribute aus, um schnell zu generieren)
ng Klassenentität/Student generierenng generate class entity/student

export class Student {
    id: number;
    name: string;
    age: number;
}
Nach dem Login kopieren

创建child component

ts

import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';
import { Student } from '../entity/student';
@Component({
  selector: 'app-child',
  templateUrl: './child.component.html',
  styleUrls: ['./child.component.css']
})
export class ChildComponent implements OnInit {
  @Input() stu: Student;
  @Output() deleteEvent = new EventEmitter<number>();
  constructor() { }
  ngOnInit() {
  }
  delete(id) {
    this.stu = null;
    this.deleteEvent.emit(id);
  }
}
Nach dem Login kopieren

html

<p *ngIf="stu">
  {{stu.id}} -- {{stu.name}} -- {{stu.age}}  <button (click)="delete(stu.id)">delete</button>
</p>
Nach dem Login kopieren

修改 app.component

ts

import { Component } from '@angular/core';
import { Student } from './entity/student';
@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  stus: Student[] = [
    {id: 1, name: '里斯', age: 3},
    {id: 2, name: '里斯2', age: 4},
    {id: 3, name: '里斯3', age: 5},
  ];
  stu: Student;
  constructor() {
  }
  selected(stu) {
    this.stu = stu;
  }
  deleteStu(id: number) {
    this.stus.forEach((val, index) => {
      if ( val.id === id) {
        this.stus.splice(index, 1);
        return;
      }
    });
  }
}
Nach dem Login kopieren

html

<p>
  <ul>
    <li *ngFor="let stu of stus" (click)="selected(stu)"> {{stu.id}} -- {{stu.name}} -- {{stu.age}} </li>
  </ul>
</p>
<app-child [stu]="stu" (deleteEvent)="deleteStu($event)"></app-child>
Nach dem Login kopieren

@Input() 很简单,就是将父组件的数据给子组件的一个属性;
@Output()rrreee

Untergeordnete Komponente erstellen

tsrrreeehtml
rrreee

App.component ändern 🎜ts🎜rrreee🎜html🎜rrreee🎜@Input() ist sehr einfach, es dient dazu, die Daten der übergeordneten Komponente einem Attribut der untergeordneten Komponente zu übergeben; 🎜@Output(); Untergeordnete Komponente Erstellen Sie einen EventEmitter. Die Operation der untergeordneten Komponente löst den EventEmitter aus und weist dann dieses EventEmitter-Objekt einer Methode der übergeordneten Komponente zu. Die geänderte Methode ruft die vom EventEmitter-Objekt angegebenen Parameter ab und verarbeitet sie sie; 🎜🎜Weitere Programmierkenntnisse finden Sie unter: 🎜Programmierunterricht🎜! ! 🎜🎜

Das obige ist der detaillierte Inhalt vonErfahren Sie mehr über @Input() und @Output() in Angular. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:cnblogs.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage