等效$编译(角2)我想手动编译一些包含指令的HTML。什么是相当于$compile角度2?例如,在角1中,我可以动态编译HTML片段并将其附加到DOM中:var e = angular.element('<div directive></div>');element.append(e);$compile(e)($scope);
3 回答
素胚勾勒不出你
TA贡献1827条经验 获得超9个赞
角形 2.3.0 (2016-12-07)
观察 (与2.3.0+一起工作)
createNewComponent (tmpl:string) {
@Component({
selector: 'dynamic-component',
template: tmpl,
})
class CustomDynamicComponent implements IHaveDynamicData {
@Input() public entity: any;
};
// a component for this particular template
return CustomDynamicComponent;}createComponentModule (componentType: any) {
@NgModule({
imports: [
PartsModule, // there are 'text-editor', 'string-editor'...
],
declarations: [
componentType ],
})
class RuntimeComponentModule
{
}
// a module for just this Type
return RuntimeComponentModule;}ComponentFactory (并缓存它)
public createComponentFactory(template: string)
: Promise<ComponentFactory<IHaveDynamicData>> {
let factory = this._cacheOfFactories[template];
if (factory) {
console.log("Module and Type are returned from cache")
return new Promise((resolve) => {
resolve(factory);
});
}
// unknown template ... let's create a Type for it
let type = this.createNewComponent(template);
let module = this.createComponentModule(type);
return new Promise((resolve) => {
this.compiler .compileModuleAndAllComponentsAsync(module)
.then((moduleWithFactories) =>
{
factory = _.find(moduleWithFactories.componentFactories
, { componentType: type });
this._cacheOfFactories[template] = factory;
resolve(factory);
});
});} // here we get Factory (just compiled or from cache)
this.typeBuilder .createComponentFactory(template)
.then((factory: ComponentFactory<IHaveDynamicData>) =>
{
// Target will instantiate and inject component (we'll keep reference to it)
this.componentRef = this
.dynamicComponentTarget .createComponent(factory);
// let's inject @Inputs to component instance
let component = this.componentRef.instance;
component.entity = this.entity;
//...
});添加回答
举报
0/150
提交
取消
