码迷,mamicode.com
首页 > 其他好文 > 详细

[Angular] Using ngTemplateOutlet to create dynamic template

时间:2017-03-06 21:01:15      阅读:315      评论:0      收藏:0      [点我收藏+]

标签:text   entry   roo   技术分享   app   generated   ted   pre   with   

I can use <tamplete> syntax and a entry component as a container to create a dynamic component. Notice it will create a empty div as a placeholder in the DOM. If we don‘t wanner this empty div, we can actually using ng-conainer together with ngTemplateOutlet (for template ref) and ngTemplateOutletContext (the context).

 

import { Component, TemplateRef, ComponentRef, ViewContainerRef, ViewChild, AfterContentInit, ComponentFactoryResolver } from @angular/core;

import { AuthFormComponent } from ./auth-form/auth-form.component;

import { User } from ./auth-form/auth-form.interface;

@Component({
  selector: app-root,
  template: `
    <div>
      <div #entry></div>
      <template #tmpl let-obj let-location="location">
          <details>
            <summary>{{obj.name}}</summary>
            <p> - Age: {{obj.age}}</p>
            <p> - Address :{{location}}</p>
          </details>
      </template>
      <hr />
      <ng-container 
      [ngTemplateOutlet]="tmpl"
      [ngTemplateOutletContext]="ctx"
      ></ng-container>
    </div>
  `
})
export class AppComponent implements AfterContentInit {

  @ViewChild(entry, { read: ViewContainerRef }) entry: ViewContainerRef;
  @ViewChild(tmpl) tmpl: TemplateRef<any>;

  ctx = {
    $implicit: {
      name: John,
      age: 34
    },
    location: USA
  }

  ngAfterContentInit() {
    this.entry.createEmbeddedView(this.tmpl, {
      $implicit: {
        name: Zhentian,
        age: 27
      },
      location: China
    })
  }

}

 

技术分享

 

And in the generated DOM we can see that there is no empty div created.

[Angular] Using ngTemplateOutlet to create dynamic template

标签:text   entry   roo   技术分享   app   generated   ted   pre   with   

原文地址:http://www.cnblogs.com/Answer1215/p/6511531.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!