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

相关内容

热门资讯

外挂步骤!佛手在线大菠萝智能辅... 外挂步骤!佛手在线大菠萝智能辅助器,hardrock作必弊-一贯是有辅助神器(哔哩哔哩)1)佛手在线...
外挂课程!wepoker安装教... 外挂课程!wepoker安装教程,智星菠萝有挂吗-总是真的有辅助攻略(哔哩哔哩)1、任何智星菠萝有挂...
外挂法子!德普之星怎么设置埋牌... 外挂法子!德普之星怎么设置埋牌,拱趴大菠萝万能挂-一贯是有辅助攻略(哔哩哔哩)拱趴大菠萝万能挂辅助器...
外挂办法!竞技联盟透视插件,x... 外挂办法!竞技联盟透视插件,xpoker辅助怎么用-确实是真的有辅助神器(哔哩哔哩)1、下载好竞技联...
外挂方针!佛手在线大菠萝为什么... 外挂方针!佛手在线大菠萝为什么都输,德普辅助软件-切实有辅助教程(哔哩哔哩)1、佛手在线大菠萝为什么...
外挂积累!约局吧德州透视,约局... 外挂积累!约局吧德州透视,约局吧如何查看是否有挂-果然存在有辅助app(哔哩哔哩)1、点击下载安装,...
外挂阶段!德州辅助工具到底怎么... 外挂阶段!德州辅助工具到底怎么样,德普之星私人局透视-确实一直都是有辅助攻略(哔哩哔哩)1、实时德州...
外挂经验!大菠萝789辅助器下... 外挂经验!大菠萝789辅助器下载,约局吧德州真的存在透视吗-果然是真的有辅助插件(哔哩哔哩)1、下载...
外挂指南!红龙poker辅助,... 外挂指南!红龙poker辅助,佛手大菠萝13道挂哪里-本来一直总是有辅助脚本(哔哩哔哩)一、佛手大菠...
外挂资料!哈糖大菠萝有挂吗,p... 外挂资料!哈糖大菠萝有挂吗,pokernow辅助工具-真是存在有辅助app(哔哩哔哩)1、每一步都需...