How to load dynamic external components into Angular application

后端 未结 1 538
一向
一向 2020-12-01 02:41

I\'m facing a problem with Angular application.

I would like to have an angular application written in Typscript build with (aot).

The aim is to display a us

相关标签:
1条回答
  • 2020-12-01 03:12

    I'm doing exactly the same. And I explain the details in this talk at NgConf.

    The first thing to understand is that Webpack cannot dynamically load modules that are unknown during build time. This is inherent to the way Webpack builds dependency tree and collects modules identifiers during build time. And it's perfectly fine since Webpack is a modules bundler, not modules loader. So you need to use a module loader and the only viable option now is SystemJS.

    Then, each plugin should be packaged as a module and all exported components should be added to the entryComponents of that module.

    During runtime, you will load that module to get access to the components declared inside if it. You don't really need a module but that's a unit of packaging in Angular so you can't avoid using it. Now, once you get a module, you have to options depending on whether the module is built using AOT or not.

    If it's built using AOT, you just get the exported factory class from the module and create a module instance:

    System.import('path/to/module').then((module)=>{
        const moduleFactory = module.moduleFactoryClassName;
        const moduleRef = moduleFactory.create(this.parentInjector);
        const resolver = moduleRef.componentFactoryResolver;
        const compFactory = resolver.resolveComponentFactory(AComponent);
    }
    

    If it's not built using AOT, you have to compile it using JIT compiler:

    System.import('path/to/module').then((module)=>{
        const moduleFactory = this.compiler.compileModuleSync(module.moduleClassName);
        const moduleRef = moduleFactory.create(this.parentInjector);
        const resolver = moduleRef.componentFactoryResolver;
        const compFactory = resolver.resolveComponentFactory(AComponent);
    }
    

    Then you can add dynamic components wherever you want using techniques described in this article: Here is what you need to know about dynamic components in Angular

    0 讨论(0)
提交回复
热议问题