ホームページ > ウェブフロントエンド > jsチュートリアル > Angular の @Input() と @Output() について学びます

Angular の @Input() と @Output() について学びます

青灯夜游
リリース: 2021-02-01 11:47:55
転載
2960 人が閲覧しました

Angular の @Input() と @Output() について学びます

#関連チュートリアルの推奨事項: angularjs(ビデオ チュートリアル)

学生クラスの作成

単純な属性はいくつかしかありません (次の属性を実行するとすぐに生成できます)


ng クラス エンティティ/学生を生成します

export class Student {
    id: number;
    name: string;
    age: number;
}
ログイン後にコピー
子コンポーネントの作成

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);
  }
}
ログイン後にコピー
html

<p *ngIf="stu">
  {{stu.id}} -- {{stu.name}} -- {{stu.age}}  <button (click)="delete(stu.id)">delete</button>
</p>
ログイン後にコピー
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;
      }
    });
  }
}
ログイン後にコピー
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>
ログイン後にコピー

@Input() これは非常に簡単で、親コンポーネントのデータを子コンポーネントのプロパティに渡すだけです;
@Output() 子コンポーネントは EventEmitter を作成します。子コンポーネントの操作により EventEmitter がトリガーされ、この EventEmitter オブジェクトが親コンポーネントのメソッドに割り当てられます。変更されたメソッドは、EventEmitter オブジェクトによって指定されたパラメータを取得して、それを処理します。 プログラミング関連の知識について詳しくは、

プログラミング教育

をご覧ください。 !

以上がAngular の @Input() と @Output() について学びますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:cnblogs.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート