实现 Angular 动态组件的问题 - AOT 和变更检测

问题描述

我正在尝试实现一个 Angular 库,它将封装将动态组件添加到 DOM 所需的逻辑。必须允许使用此库的应用程序提供动态组件列表,然后定义必须在运行时插入这些动态组件的“出口”。

我的代码深受两篇文章的启发:

我的代码的基本结构如下:

  • 带有模块 ng-dynamic-components 的库 NgDynamicComponentsModule,它允许使用者定义可在运行时添加到 DOM 的组件列表
  • 维护此类动态组件及其组件工厂的注册表的服务,用于在需要时实例化组件
  • 一个插座组件,它使用 ViewContainerRef 处理实际将动态组件放入 DOM 的逻辑
  • 一个 dynamic-test-app,它导入这个库并使用一些动态注入的测试组件来使用它——OneComponentTwoComponentThreeComponent

我的代码位于:https://github.com/kiranjholla/ng-dynamic-components。要运行我的代码,只需克隆这个 Git 存储库,然后输入 npm installnpm start。这将首先使用选项 --prod 构建库,然后使用选项 --prod --aot=false --buildOptimizer=false 构建测试应用程序,然后启动一个 http-server 实例来为 dist 文件夹提供服务

现在我的问题是:上述代码仅在应用程序使用 --aot=false --buildOtimizer=false 构建时才有效;启用 AOT 后,我收到一条错误消息,指出编译器不可用。

enter image description here

但是,我已经提供了专门使用 JitCompilerFactory 的编译器。我怎样才能让它与 AOT 一起工作?

任何帮助/指示,非常感谢。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...