内容投影

你可以使用位于@abp/ng.core包中的 ContentProjectionService 简单明确的投影内容.

入门

你不必在模块或组件级别提供 ContentProjectionService,因为它已经在根中提供了. 你可以在组件中注入并开始使用它. 为了获得更好的类型支持,你可以将迭代项目的类型传递给它.

  1. import { ContentProjectionService } from '@abp/ng.core';
  2. @Component({
  3. /* class metadata here */
  4. })
  5. class DemoComponent {
  6. constructor(private contentProjectionService: ContentProjectionService) {}
  7. }

用法

你可以使用 ContentProjectionServiceprojectContent 方法在你的项目中动态的渲染组件和模板.

如何将组件投影到根级别

如果将 RootComponentProjectionStrategy 做为 projectContent 方法的第一个参数,那么 ContentProjectionService 会解析投影组件并放在根级别,它还为组件传递上下文.

  1. const strategy = PROJECTION_STRATEGY.AppendComponentToBody(
  2. SomeOverlayComponent,
  3. { someOverlayProp: "SOME_VALUE" }
  4. );
  5. const componentRef = this.contentProjectionService.projectContent(strategy);

在上面的示例中, SomeOverlayComponent 组件放置在 <body>末尾并返回 ComponentRef. 另外将应用给定的上下文,因此组件的 someOverlayProp 被设置为 SOME_VALUE.

你应该总是返回 ComponentRef 实例,因为它是对投影组件的引用,在你需要时使用该引用销毁投影视图和组件实例.

如何将组件和模板投影到容器中

如果将 ComponentProjectionStrategyTemplateProjectionStrategy 做为 projectContent 方法的第一个参数,并且传递 ViewContainerRef 做为策略的第二个参数传递. 那么 ContentProjectionService 把组件或模板投影到给定的容器中,它还为组件或模板传递上下文.

  1. const strategy = PROJECTION_STRATEGY.ProjectComponentToContainer(
  2. SomeComponent,
  3. viewContainerRefOfTarget,
  4. { someProp: "SOME_VALUE" }
  5. );
  6. const componentRef = this.contentProjectionService.projectContent(strategy);

在上面的示例中,viewContainerRefOfTarget(它是一个ViewContainerRef 实例)将被清除,并把 SomeComponent 组件放在其中. 另外将应用给定的上下文,因此组件的 someProp 被设置为 SOME_VALUE.

你应该总是返回 ComponentRefEmbeddedViewRef ,因为它是对投影内容的引用,在你需要时使用该引用销毁它们.

请参考ProjectionStrategy查看所有可用的投影策略以及如何构建自己的投影策略.

API

projectContent

  1. projectContent<T extends Type<any> | TemplateRef<any>>(
  2. projectionStrategy: ProjectionStrategy<T>,
  3. injector = this.injector,
  4. ): ComponentRef<C> | EmbeddedViewRef<C>
  • projectionStrategy 参数是此处的要点,在上面进行了说明.
  • injector 参数是 Injector 实例,你可以传递到投影内容. 在 TemplateProjectionStrategy 并没有使用到它.

下一步是什么?