Angular动态加载模块需要使用根注入器服务。
创始人
2024-10-24 14:31:17
0

在Angular中,动态加载模块需要使用根注入器服务。以下是一个示例解决方法:

  1. 首先,创建一个名为DynamicModuleLoaderService的服务,用于加载动态模块。在该服务中,注入CompilerInjector服务。
import { Compiler, Injectable, Injector, NgModuleFactory, NgModuleRef, Type } from '@angular/core';

@Injectable({
  providedIn: 'root',
})
export class DynamicModuleLoaderService {
  constructor(private compiler: Compiler, private injector: Injector) {}

  async loadModule(moduleType: Type): Promise> {
    const moduleFactory = await this.compiler.compileModuleAsync(moduleType);
    return moduleFactory.create(this.injector);
  }
}
  1. 创建一个名为DynamicComponentLoaderDirective的指令,用于动态加载组件。在该指令中,注入DynamicModuleLoaderServiceViewContainerRef服务。
import { Directive, Input, OnInit, ViewContainerRef } from '@angular/core';
import { DynamicModuleLoaderService } from './dynamic-module-loader.service';

@Directive({
  selector: '[appDynamicComponentLoader]',
})
export class DynamicComponentLoaderDirective implements OnInit {
  @Input() moduleType: any;

  constructor(
    private dynamicModuleLoaderService: DynamicModuleLoaderService,
    private viewContainerRef: ViewContainerRef
  ) {}

  ngOnInit(): void {
    this.dynamicModuleLoaderService
      .loadModule(this.moduleType)
      .then((moduleRef) => {
        const moduleFactory = moduleRef.componentFactoryResolver.resolveComponentFactory(this.moduleType);
        this.viewContainerRef.createComponent(moduleFactory);
      });
  }
}
  1. 在需要动态加载模块的组件模板中,使用appDynamicComponentLoader指令并传入待加载的模块类型。

  

在上述代码中,DynamicModule是动态加载的模块类型,shouldLoadModule是一个布尔值,用于控制是否加载模块。

这样,当shouldLoadModuletrue时,DynamicModule就会被动态加载并显示在组件中。

相关内容

热门资讯

黑科技辅助挂!红龙扑克辅助器下... 黑科技辅助挂!红龙扑克辅助器下载,红龙扑克ai,一向真的是有挂(2024已更新)-哔哩哔哩;精心打造...
黑科技有挂!红龙扑克辅助器下载... 黑科技有挂!红龙扑克辅助器下载地址,轰趴大菠萝十三水有外挂,一贯真的有挂(2023已更新)-哔哩哔哩...
黑科技脚本!红龙扑克是不是有问... 黑科技脚本!红龙扑克是不是有问题,德扑之星创建房间设置,原本真的是有挂(2021已更新)-哔哩哔哩;...
黑科技存在!红龙扑克app辅助... 黑科技存在!红龙扑克app辅助器,cloudpoker外挂,其实有挂(2026已更新)-哔哩哔哩;大...
黑科技规律!红龙扑克透牌规则,... 黑科技规律!红龙扑克透牌规则,德扑线上创建房间,本然有挂(2020已更新)-哔哩哔哩;最新版2024...
黑科技最新!智星德州菠萝有挂吗... WePoke高级策略深度解析‌;黑科技最新!智星德州菠萝有挂吗,轰趴大菠萝怎么提高胜率,原先有挂(2...
黑科技辅助挂!红龙扑克辅助器,... WePoker透视辅助版本稳定性对比与推荐‌:黑科技辅助挂!红龙扑克辅助器,智星德州菠萝安全吗,原生...
黑科技辅助挂!红龙扑克辅助器,... 黑科技辅助挂!红龙扑克辅助器,德扑之星操作,切实是有挂(2026已更新)-哔哩哔哩;亲们利用一分钟了...
黑科技有挂!红龙扑克ai,德扑... 红龙扑克ai赢率提升策略‌;黑科技有挂!红龙扑克ai,德扑之星带入记分牌,一直真的有挂(2024已更...
黑科技辅助挂挂!红龙扑克ai辅... 1、黑科技辅助挂挂!红龙扑克ai辅助,德扑之星电脑版,固有是有挂(2025已更新)-哔哩哔哩;详细教...