我有一个简单的组件
@Component({
selector: '[my-component]',
template: `<i>1</i><p>content</p><b>2</b>`
})
export class MyComponent {
public tagName: string;
}
另一个实例化第一个:
export class AppComponent implements OnInit {
@ViewChild("myContainer", { read: ViewContainerRef }) container;
constructor(
private viewContainer: ViewContainerRef,
private resolver: ComponentFactoryResolver) {
}
ngOnInit() {
this.container.clear();
const compFactory = this.resolver.resolveComponentFactory(MyComponent);
const componentRef = this.container.createComponent(compFactory);
componentRef.instance.tagName = 'span';
}
}
的模板AppComponent
只是
<template #myContainer></template>
,所以输出是
<div my-component><i>1</i><p>content</p><b>2</b></div>
我要做的是MyComponent
在实例化期间自定义模板并将其p
标签替换为名称应该为tagName
. 在执行方法MyComponent
时,我在创建之前就知道标签的名称。AppComponent.ngOnInit
我试图解决的另一项任务是MyComponent
包装标签名称定制。替换<div my-component>...
为<span my-component>...
"span" 是所需的标签名称,也称为AppComponent.ngOnInit
.
那么是否有可能以编程方式提供这样的定制并获得以下信息:
<span my-component><i>1</i><span>content</span><b>2</b></span>
? tagName
可以是任何允许的 HTML 标记,并且 ngIf/Switch 不是一个选项。我为快速潜水创建了演示:https ://stackblitz.com/edit/angular-zngyoa