问题描述
我在使用内容投影对嵌套动态组件进行更改检测时遇到问题。 更改检测不会在子组件上自动触发,我必须为每个操作添加手动更改检测。
这里的一个例子:https://stackblitz.com/edit/angular-ivy-k2z661?file=src%2Fapp%2Fapp.component.ts
如您所见,如果您单击按钮,则不会显示任何内容,但是在 add() 函数上添加 this.cdr.detectChanges()
行时,会显示内容。
此外,您会注意到我没有使用
ChangeDetectionStrategy.OnPush
有没有办法在不随处添加手动更改检测的情况下实现这一目标?
解决方法
所以我终于知道是怎么回事了。子视图需要手动附加到 appref。所以
private appRef: ApplicationRef
需要添加到构造函数中,然后附加子视图:
this.appRef.attachView(refChild.hostView);
我已经更新了 Stackblitz。