首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >角度2:加载innerHTML中的动态部件

角度2:加载innerHTML中的动态部件
EN

Stack Overflow用户
提问于 2017-03-16 14:21:30
回答 1查看 1.3K关注 0票数 1

我有两个@组件,比如说和。现在,我必须像innerHTML那样动态加载,例如,如下所示

component-1.html

代码语言:javascript
复制
<div [innerHTML]="domEl | safeHtml"></div>

在Angular2组件-1类中

代码语言:javascript
复制
import {
  Component,
  OnInit,
  ViewEncapsulation
} from '@angular/core';


@Component({  
  selector: 'component-1',

  templateUrl: './component-1.html',

  encapsulation: ViewEncapsulation.None
})
export class Component1 implements OnInit {    

  public ngOnInit() {
    this.domEl = '<component-2 data="1234"></component-2>'
  }
}

组件-2已经通过declarations[]注入到declarations[]文件中。safeHtml也是用于安全的HTML转换的管道。

即使这样,问题是组件-2没有加载。有人能建议我怎么解决这个问题吗?

注意:

  • 如果我直接将组件-2包含在组件-1.html中,它就会工作。但是有一种情况,我们不能动态地注入组件-2。
  • 堆栈是在Angular2、TypeScript和Webpack的基础上构建的。
EN

回答 1

Stack Overflow用户

发布于 2017-05-09 16:56:28

除了出于安全目的的净化之外,Angular不处理传递给[innerHTML]="..."的HTML。绑定组件指令..。没有创建,因为如前所述,角忽略了内容。您可以做的是在运行时创建一个组件,就像在Equivalent of $compile in Angular 2中解释的那样。一旦有人建立了一个模块,使这更容易,但我不记得细节。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42836736

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档