不同模块加载的Angular组件不能在动态编译的组件中呈现
创始人
2025-01-09 11:30:39
0

在动态编译的组件中,必须将不同模块中的组件加入到模块中。您可以使用NgModule的imports属性来实现这一点。下面是一个示例:

import { NgModule }      from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { FormsModule }   from '@angular/forms';
import { AppComponent }  from './app.component';
import { DynamicComponent } from './dynamic.component';
import { OtherModule } from './other.module';

@NgModule({
  imports: [
    BrowserModule,
    FormsModule,
    OtherModule // 加载其他模块
  ],
  declarations: [
    AppComponent,
    DynamicComponent
  ],
  bootstrap: [ AppComponent ]
})
export class AppModule { }

在这个示例中,我们加载了一个名为“OtherModule”的模块,并将其添加到NgModule的imports数组中。然后,在NgModule的declarations数组中添加了一个动态组件,其中包含了来自“OtherModule”的组件。

当我们在动态编译的组件中引用这个NgModule时,我们也可以使用来自“OtherModule”的组件了:

import { NgModule, Compiler, Component, Input, NgModuleRef, OnInit } from '@angular/core';

@Component({
  selector: 'dynamic-comp',
  template: ``
})
export class DynamicComponent implements OnInit{
  @Input() module: NgModuleRef;
  @Input() selector: string;

  constructor(private compiler: Compiler) {}

  ngOnInit() {
    const factory = this.compiler.compileModuleAndAllComponentsSync(this.module);
    const compFactory = factory.componentFactories.find(x => x.selector === this.selector);

    if (compFactory) {
      const component = compFactory.create(this.injector);
      this.container.insert(component.hostView);
    }
  }
}

在这个示例中,我们使用Angular Compiler来编译包含在模块中的组件。然后我们可以通过selector属性指定要渲染的组件。这样,我们就可以在动态编译的

相关内容

热门资讯

现场直击!决战十水三余音,we... 现场直击!决战十水三余音,wepoker透视脚本苹果版,绝活儿教程(有挂秘诀)-哔哩哔哩1、wepo...
透视脚本!德普之星有辅助软件吗... 透视脚本!德普之星有辅助软件吗,德普辅助软件(透视)本来真的是有挂(了解有挂)-哔哩哔哩;在进入德普...
透视ai!德普之星私人局透视,... 透视ai!德普之星私人局透视,德普之星透视辅助(透视)好像是有挂(有挂猫腻)-哔哩哔哩1、在德普之星...
现场直击!hhpoker怎么破... 现场直击!hhpoker怎么破解,hhpoker底牌透视脚本,烘培教程(有挂功能)-哔哩哔哩小薇(辅...
透视讲解!德普之星辅助器app... 透视讲解!德普之星辅助器app,德普之星透视软件免费入口官网(透视)果然是有挂(有挂方法)-哔哩哔哩...
现有说明如下!闲逸辅助脚本,雀... 现有说明如下!闲逸辅助脚本,雀友会潮汕图片辅助器,窍门教程(有人有挂)-哔哩哔哩1、每一步都需要思考...
透视了解!德普之星怎么开辅助,... 透视了解!德普之星怎么开辅助,德普之星私人局透视(透视)本来真的有挂(有挂秘诀)-哔哩哔哩1、点击下...
据通报!樱花之盛辅助真的假的,... 据通报!樱花之盛辅助真的假的,hhpoker德州透视挂,办法教程(有挂细节)-哔哩哔哩所有人都在同一...
截至目前!茶馆游戏辅助,微乐小... 截至目前!茶馆游戏辅助,微乐小程序脚本,攻略教程(有挂辅助)-哔哩哔哩微乐小程序脚本脚本下载中分为三...
透视讲解!德普之星辅助工具如何... 透视讲解!德普之星辅助工具如何设置,如何下载德普之星辅助软件(透视)真是存在有挂(有挂解惑)-哔哩哔...