Angular指令不会接收来自在ngOnDestroy方法中更新的组件的更改
创始人
2024-10-30 22:30:26
0

在Angular中,当从组件中使用ngOnDestroy方法更新指令中的值时,指令不会自动更新。这是因为指令和组件之间的数据流是单向的。要解决这个问题,可以使用Angular的@Input和@Output注释。

在组件中,我们可以使用@Output注释将值传递给父指令。在父指令中,我们可以使用@Input注释来接收来自组件的值。这样,即使在ngOnDestroy方法中更新组件,父指令也会更新其自己的值。

下面是一个示例代码:

// 在组件中 @Component({ selector: 'app-root', template: }) export class AppComponent implements OnDestroy { @Output valueChanged = new EventEmitter(); value = '';

ngOnDestroy() { this.valueChanged.emit(this.value); }

emitValue() { this.valueChanged.emit(this.value); } }

// 在指令中 @Directive({ selector: '[appMyDirective]' }) export class MyDirective { @Input() appMyDirective: string;

@Input() set value(value: string) { this.appMyDirective = value; // 其他操作 } }

在这个例子中,我们将应用一个名为MyDirective的自定义指令。 当在AppComponent组件中更新值时,会触发valueChanged事件并向父指令发送更新后的值。 父指令将使用输入中的值来更新其自己的值。 父指令中的任何在值改变时执行的其他操作都将继续执行。

现在来处理ngOnDestroy方法。 当AppComponent销毁时,我们将触发ngOnDestroy方法并通过valueChanged事件将最新值发送到父指令。 父指令将使用更新

相关内容

热门资讯

事发当天!微信小程序辅助软件有... 事发当天!微信小程序辅助软件有哪些!总是有挂辅助下载(竟然有挂)-哔哩哔哩微信小程序辅助软件有哪些透...
此事引发网友热议!家家盘锦开挂... 此事引发网友热议!家家盘锦开挂!本来真的有辅助挂(有挂分析)-哔哩哔哩1、在家家盘锦开挂插件功能辅助...
做出回应!悟空大厅辅助!真是是... 做出回应!悟空大厅辅助!真是是真的辅助神器(有挂猫腻)-哔哩哔哩一、悟空大厅辅助游戏安装教程牌型概率...
截至发稿!同乡游辅助软件!其实... 截至发稿!同乡游辅助软件!其实存在有辅助安装(有挂规律)-哔哩哔哩1、起透看视 同乡游辅助软件辅助软...
一直以来!微信小程序指尖四川辅... 一直以来!微信小程序指尖四川辅助器!一贯真的有辅助安装(有挂实锤)-哔哩哔哩1、微信小程序指尖四川辅...
为切实保障!全托中至窝龙拿好牌... 为切实保障!全托中至窝龙拿好牌!好像是有辅助下载(确实有挂)-哔哩哔哩全托中至窝龙拿好牌脚本下载中分...
出乎意料的是!圣游科技!切实存... 出乎意料的是!圣游科技!切实存在有辅助神器(有挂分享)-哔哩哔哩1、首先打开圣游科技辅助器下载最新版...
截至发稿!捉住捣蛋鸡作z弊码!... 截至发稿!捉住捣蛋鸡作z弊码!都是存在有辅助器(有挂规律)-哔哩哔哩1、操作简单,无需捉住捣蛋鸡作z...
据目击者称!宝宝浙江游戏有没有... 据目击者称!宝宝浙江游戏有没有辅助器!都是存在有辅助app(果真有挂)-哔哩哔哩1、每一步都需要思考...
现就发布提示!福州十八扑外卦视... 现就发布提示!福州十八扑外卦视频!切实是真的辅助神器(有挂透视)-哔哩哔哩1、下载好福州十八扑外卦视...