zoukankan      html  css  js  c++  java
  • [Angular] Dynamic components with ComponentFactoryResolver

    To create a component dynamicly.

    1. Add a container with ref:

    @Component({
      selector: 'app-root',
      template: `
        <div>
          <div #entry>
            <!-- We want to create auth-form component inside this div-->
          </div>
        </div>
      `
    })

    2. View this container as ViewContainerRef.

    @ViewChild('entry', {read: ViewContainerRef}) entry: ViewContainerRef;

    3. We need ComponentFactoryResolver:

      constructor(private resolver: ComponentFactoryResolver) {
    
      }

    4. We will create compoennt after content init:

    export class AppComponent implements AfterContentInit{
      ngAfterContentInit() {
    
      }
    }

    5. Create factory by using resolver:

      ngAfterContentInit() {
        const factory = this.resolver.resolveComponentFactory(AuthFormComponent);
       
      }

    6. Create component by using viewContainerRef:

      ngAfterContentInit() {
        const factory = this.resolver.resolveComponentFactory(AuthFormComponent);
        this.entry.createComponent(factory);
      }

    7. Make sure, you add entryComponent:

    @NgModule({
      declarations: [
        AuthFormComponent,
        AuthRememberComponent,
        AuthMessageComponent
      ],
      imports: [
        CommonModule,
        FormsModule
      ],
      exports: [
        AuthFormComponent,
        AuthRememberComponent
      ],
      entryComponents: [
        AuthFormComponent
      ]
    })

    // app.component:
    
    import {Component, ViewContainerRef, ViewChild, ComponentFactoryResolver, AfterContentInit} 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>
            <!-- We want to create auth-form component inside this div-->
          </div>
        </div>
      `
    })
    export class AppComponent implements AfterContentInit{
    
      @ViewChild('entry', {read: ViewContainerRef}) entry: ViewContainerRef;
    
      constructor(private resolver: ComponentFactoryResolver) {
    
      }
    
      ngAfterContentInit() {
        const factory = this.resolver.resolveComponentFactory(AuthFormComponent);
        this.entry.createComponent(factory);
      }
    
      loginUser(user: User) {
        console.log('Login', user);
      }
    
    }
  • 相关阅读:
    C#基础知识简单梳理
    knearest neighbor
    二叉查找树的实现
    Unix/Linux 那些系统启动后的进程
    Nginx反向代理IIS
    线程漫谈——线程同步之信号量和互斥量
    BtxCMS@B.T.X 项目及界面展示 [下载]
    MVC in MFC or WTL
    HTTP HTTPS WebService
    ASP.NET WebAPI RC 竟然不支持最常用的json传参
  • 原文地址:https://www.cnblogs.com/Answer1215/p/6436501.html
Copyright © 2011-2022 走看看