如何使用带有数据表的ts代码中的@ViewChild从父组件向子视图注入DOM

时间:2017-02-16 16:15:32

标签: angular typescript dynamic angular2-template viewchild

这是创建数据表的父组件:

 import {CollectedItemsDynamic} from "../collected-items-datatable/collected-items-dynamicView";
    declare var $: any;

    @Component({
      selector: 'sa-datatable-roi',
      template: `<table class="dataTable {{tableClass}}" width="{{width}}">
            <ng-content></ng-content>
          </table>`,          
    })
    export class DatatableComponent implements OnInit {

      @ViewChild(CollectedItemsDynamic) collectedItemsDynamic: CollectedItemsDynamic;

      ngOnInit() {
        this.render()    
      }

      render() {
        let element = $(this.el.nativeElement.children[0]);
        let options = this.options

        const _dataTable = element.DataTable(options);


          element.on('click', 'td.details-control', function () {
            var tr = $(this).closest('tr');
            var row = _dataTable.row( tr );
            if ( row.child.isShown() ) {
              row.child.hide();
              tr.removeClass('shown');
            }
            else {
              row.child( -----> Inject_here_the_CollectedItemsDynamic_template <----- ).show();
              tr.addClass('shown');
            }
          })
        }
    }

这是动态组件:

import {Component, Input, ElementRef, AfterContentInit, OnInit} from '@angular/core';

declare var $: any;


    @Component({
        selector: 'collected-items-dynamic',
        templateUrl: `
                 <td><button (click)="test()"></button></br></br></td>               
    `,
    })

    export class CollectedItemsDynamic{

        public test() {
            console.log(test);
        }
    }

我想使用row.child( -----> Inject_here_the_CollectedItemsDynamic_template <-----).show();

在行之后注入CollectedItemsDynamic组件的html模板

那应该在所选行之后添加一个,并且按钮单击应该打印到控制台== CollectedItemsDynamic中的绑定应该有效。

有没有办法将CollectedItemsDynamic注入DatatableComponent的DOM?

0 个答案:

没有答案