Angular笔记(三)组件交互
创始人
2025-06-01 06:46:18
0

文章目录

    • 一、Input
    • 二、Input:setter
    • 三、ngOnChanges() 监测
    • 四、Output
    • 五、本地变量#表示组件
    • 六、父级调用 @ViewChild()
    • 七、服务 service

一、Input

子:

@Input() hero!: Hero;
@Input('master') masterName = ''; //不推荐起别名

父:

//html:
 
//ts:
export class HeroParentComponent {hero = '';master = 'Master';
}

二、Input:setter

使用一个输入属性的 setter,以拦截父组件中值的变化,并采取行动。

e.g. 子组件 NameChildComponent 的输入属性 name 上的这个 setter,会 trim 掉名字里的空格,并把空值替换成默认字符串。

子:

export class NameChildComponent {@Input()get name(): string { return this._name; }set name(name: string) {this._name = (name && name.trim()) || '';}private _name = '';
}

父:

//html

//ts
export class NameParentComponent {// Displays 'Dr. IQ', '', 'Bombasto'names = ['Dr. IQ', '   ', '  Bombasto  '];
}

三、ngOnChanges() 监测

使用 OnChanges 生命周期钩子接口的 ngOnChanges() 方法来监测输入属性值的变化并做出回应。

当需要监视多个、交互式输入属性的时候,本方法比用属性的 setter 更合适。

四、Output

子组件暴露一个 EventEmitter 属性,当事件发生时,子组件利用该属性 emits(向上弹射)事件。
父组件绑定到这个事件属性,并在事件发生时作出回应。
【 子组件的 EventEmitter 属性是一个输出属性,通常带有**@Output** 装饰器 】

本框架把事件参数(用 $event 表示)传给事件处理方法

子:

//html

//ts
@Output() voted = new EventEmitter();
vote(agreed: boolean) {this.voted.emit(agreed);
}

父:

//html

//ts
onVoted(agreed: boolean) { //Todo }

五、本地变量#表示组件

父组件不能使用数据绑定来读取子组件的属性或调用子组件的方法。但可以在父组件模板里,新建一个本地变量来代表子组件,然后利用这个变量来读取子组件的属性和调用子组件的方法。

子:

//ts
start() { this.countDown(); }
stop()  {this.clearTimer(); }

父:

//html


{{timer.seconds}}

Q:父组件不能通过数据绑定使用子组件的 start 和 stop 方法,也不能访问子组件的 seconds 属性。

A:把本地变量(#timer)放到()标签中,用来代表子组件。
这样父组件的模板就得到了子组件的引用,于是可以在父组件的模板中访问子组件的所有属性和方法。

六、父级调用 @ViewChild()

这个本地变量方法是个简单明了的方法。
局限性:父组件本身的代码对子组件没有访问权【父组件-子组件的连接全部在父组件的模板中进行】
=> 如果父组件的类需要依赖于子组件类,就不能使用本地变量方法。

父:

//html


{{ seconds() }}
//ts export class CountdownViewChildParentComponent implements AfterViewInit {@ViewChild(CountdownTimerComponent)private timerComponent!: CountdownTimerComponent; //子组件seconds() { return 0; }ngAfterViewInit() {// Redefine `seconds()` to get from the `CountdownTimerComponent.seconds` ...// but wait a tick first to avoid one-time devMode// unidirectional-data-flow-violation errorsetTimeout(() => this.seconds = () => this.timerComponent.seconds, 0);}start() { this.timerComponent.start(); }stop() { this.timerComponent.stop(); } }
  1. 必须导入对装饰器 ViewChild 以及生命周期钩子 AfterViewInit 的引用
  2. 通过 @ViewChild 属性装饰器,将子组件 CountdownTimerComponent 注入到私有属性 timerComponent 里面
  3. 把按钮绑定到父组件自己的 start 和 stop 方法,使用父组件的 seconds 方法的插值

ngAfterViewInit() 生命周期钩子是非常重要的一步。
被注入的计时器组件只有在 Angular 显示了父组件视图之后才能访问,所以它先把秒数显示为 0。

七、服务 service

父组件和它的子组件共享同一个服务,利用该服务在组件家族内部实现双向通讯

相关内容

热门资讯

观沧海日月之行赏析   观沧海日月之行赏析  赏析诗歌要知人论世,例如,了解作者生平和诗风,分析写作背景等。  《观沧海...
卞之琳诗歌 卞之琳诗歌  卞之琳(1910-2000),著有诗集《三秋草》(1933)、《鱼目集》(1935)、...
传统过年民俗诗歌介绍 传统过年民俗诗歌介绍  春节是中国最重要最隆重的传统节日。农历正月初一是一年的'开始,接下来小编为你...
建党100周年青春建功新时代... 2021年,我们迎来了建党100周年,新时代的新青年们,请以青春之名、以奋斗之姿建功新时代吧。那建党...
浅语优秀爱情诗歌 浅语优秀爱情诗歌  你说 爱是缘分  可我不曾相见那未知的温柔  我说 情是深浅  可你不曾去寻那隐...
《不醉不归》诗歌 《不醉不归》诗歌  在一个只有猪和草的世界里  黑褐色的狂吃  遮天盖地  子孙后代的身体  瘦得只...
陈毅诗词 陈毅诗词大全  诗词,是指以古体诗、近体诗和格律词为代表的中国古代传统诗歌。亦是汉字文化圈的特色之一...
描写秋天的文艺诗歌大全5篇 在日常学习、工作或生活中,说到诗歌,大家肯定都不陌生吧,诗歌是表现诗人思想感情的一种文学样式。你知道...
现代诗歌金波 现代诗歌金波(精选7首)  在日常生活或是工作学习中,大家一定都接触过一些使用较为普遍的诗歌吧,诗歌...
月亮边的妹妹诗歌 月亮边的妹妹诗歌  遥遥银河边缘  悠悠白云深处  驻守着我的妹妹  美丽善良的妹妹  你是晚霞疲惫...
歌颂劳动者的诗歌朗诵 歌颂劳动者的诗歌朗诵(精选13首)  无论在学习、工作或是生活中,大家都收藏过自己喜欢的诗歌吧,诗歌...
题李凝幽居诗词赏析 题李凝幽居诗词赏析  【诗人简介】  贾岛:(779-843),字阆仙,范阳(今北京)人。早年出家为...
语文诗词的手抄报 关于语文诗词的手抄报  导语:诗词,是指以古体诗、近体诗和格律词为代表的中国古代传统诗歌。亦是汉字文...
对李白《行路难》的赏析 对李白《行路难》的赏析  在日常的学习、工作、生活中,大家都经常接触到诗歌吧,诗歌具有精炼含蓄的特点...
爱情古诗句唯美图片 爱情古诗句唯美图片  不要承诺,不要誓言,只要用一杯茶的温度,品茗一生的幸福。有一种牵挂,在心底反复...
雨霖铃柳永全文及翻译 雨霖铃柳永全文及翻译  《雨霖铃·寒蝉凄切》是宋代词人柳永的词作。此词上片细腻刻画了情人离别的场景,...
林清玄《阳光的味道》全文 林清玄《阳光的味道》全文  林清玄中国著名文化学者,理论家、文化史学家、作家 、散文家。下面是《阳光...
汪藻《春日》原文及译文 汪藻《春日》原文及译文  《春日》是北宋诗人汪藻创作的一首七言律诗。这首诗通过对春日出游的见闻感受的...
于春的诗句 于春的诗句  1) 满目山河空念远,落花风雨更伤春。 ——出处: 晏殊《浣溪沙•一向年光有...
与颜色有关的诗句 与颜色有关的诗句  诗句就是组成的句子。诗句通常按照诗文的格式体例,限定每句字数的多少。以下是小编帮...