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事件将最新值发送到父指令。 父指令将使用更新

相关内容

热门资讯

透视妙招!如何下载wpk透视版... 透视妙招!如何下载wpk透视版,wpk俱乐部有没有辅助(透视)都是真的是有脚本神器(哔哩哔哩)1、下...
透视模块!竞技联盟透视,hhp... 透视模块!竞技联盟透视,hhpoker作必弊实战视频(透视)都是有挂(哔哩哔哩)1、完成hhpoke...
透视策略!wepoker的辅助... 透视策略!wepoker的辅助器,wepoker辅助器免费(透视)竟然是有挂(哔哩哔哩)一、wepo...
透视烘培!wpk辅助器是真的吗... 透视烘培!wpk辅助器是真的吗,wpk辅助器是真的吗(透视)一贯是有透视挂(哔哩哔哩)wpk辅助器是...
透视积累!pokemmo脚本,... 透视积累!pokemmo脚本,wepoker辅助是真的吗(透视)果然真的有挂(哔哩哔哩)一、wepo...
透视策略!hhpoker真的假... 透视策略!hhpoker真的假的,hhpoker作必弊实战视频(透视)果然有透视工具(哔哩哔哩)1、...
透视绝活!wepoker怎么拿... 透视绝活!wepoker怎么拿到好牌,wepoker底牌透视脚本(透视)竟然存在有挂(哔哩哔哩)1、...
透视要领!wepoker透视底... 透视要领!wepoker透视底牌,wepoker透视方法(透视)本来是有透视器(哔哩哔哩)1、进入到...
透视模块!德州透视hhpoke... 透视模块!德州透视hhpoker,wepoker钻石怎么看底牌(透视)果然是有挂(哔哩哔哩)1、首先...
透视大纲!wpk透视工作室,w... 透视大纲!wpk透视工作室,wpk软件是真的吗(透视)其实是真的透视工具(哔哩哔哩)1、许多玩家不知...