Angular2父子组件之间数据传递:@Input和@Output (下) ...

为了让大家学习起来轻松、易懂,小编尽量做到篇幅短,语言通俗易懂,知识点分段来讲,以免太长了看起来很累,也很容易失去耐心阅读下去,希望大家理解和支持,同时希望大家点赞和分享出去,让更多的志同道合的朋友来学习


子组件向父组件传递数据
使用事件传递是子组件向父组件传递数据最常用的方式,子组件需要实例化EventEmitter类来订阅和触发自定义事件


第一步定义子组件

childenComponent.ts(子组件)

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

@Component({
  
selector'app-childen',
  
templateUrl'./childen.component.html',
  
styleUrls: ['./childen.component.css']
})

export class ChildenComponent {
  @Output() 
event new EventEmitter();
  private 
namestring;


  
upward() {
    
this.event.emit(this.name);
  
}
}

(1).实例化EventEmitter,赋值给event,event被@Output装饰器定义为输出属性,这样event具备了向上级传递数据的能力,通过调用EventEmitter类中定义的emit方法,来向上传递数据

 

(2).定义一个name属性,用于接受子组件页面的输入

 

(3).定义upward方法,用于子组件页面点击事件 触发事件调用,upward()方法里面调用自定义事件event来触发emit方法 传递数据

childenComponent.html(子组件模版)

class="childen-box">
 

子组件


 

    type="text" [(ngModel)]="name">
    type="button" (click)="upward()" value="传递数据给父组件">
 


第二步定义父组件

parentComponent.ts(父组件)

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

@Component({
 
selector: 'app-parent',
 
templateUrl: './parent.component.html',
 
styleUrls: ['./parent.component.css']
})

export class ParentComponent {
 
private parent_name: string;

 
getData(event) {
   
this.parent_name = event;
 
}

}

parentComponent.html(父组件模版)

class="parent_div">
 

父组件


 

    接收子组件数据:{ { parent_name}}
 

 

 
(event)="getData($event)">
 

父组件通过绑定自定义事件event ,来订阅来自子组件触发事件(这里是点击事件),当我们点击子组件上面的按钮,调用子组件的upward()方法,内部实现会调用this.event.emit(this.name);传递数据,自此父组件就能够监听自定义事件event。调用getData来接收传递过来的数据

 

最终效果:表单输入数据,点击页面按钮,数据传递到父组件,在显示出来

Angular2父子组件之间数据传递:@Input和@Output (下) ..._第1张图片


<完>


个人学习心得,大神路过,不喜勿喷

转载于:https://www.cnblogs.com/long328583644/p/7142112.html

你可能感兴趣的:(javascript)