ng generate class entity/student
export class Student {
id: number;
name: string;
age: number;
}
創(chuàng)建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);
}
}
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() 很簡(jiǎn)單,就是將父組件的數(shù)據(jù)給子組件的一個(gè)屬性;@Output() 子組件創(chuàng)建一個(gè) EventEmitter, 子組件的操作會(huì)觸發(fā)EventEmitter ,然后將這個(gè) EventEmitter 對(duì)象賦值給 父組件的一個(gè) method ,改方法會(huì)拿到EventEmitter對(duì)象給的參數(shù),然后進(jìn)行處理;
更多編程相關(guān)知識(shí),可訪問(wèn):編程教學(xué)??!
更多關(guān)于云服務(wù)器,域名注冊(cè),虛擬主機(jī)的問(wèn)題,請(qǐng)?jiān)L問(wèn)西部數(shù)碼官網(wǎng):m.ps-sw.cn