2017-02-04 92 views
0

我想要使用數據表,並有能力有一個擴展的子行,而點擊+它將花費行和顯示額外的數據與一些按鈕綁定這是在移動到角2之前的ajax版本:enter image description hereAngular 2 Datatable展開式行與自定義HTML綁定

每行一個子行用於附加操作和信息。

以下是部分:

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

declare var $: any; 

@Component({ 

    selector: 'sa-datatable', 
    template: ` 
     <table class="dataTable {{tableClass}}" width="{{width}}"> 
     <ng-content></ng-content> 
     </table> 
`, 
    styles: [ 
    require('smartadmin-plugins/datatables-bundle/datatables.min.css') 
    ] 
}) 
export class DatatableComponent implements OnInit { 

    @Input() public options:any; 
    @Input() public filter:any; 
    @Input() public detailsFormat:any; 

    @Input() public paginationLength: boolean; 
    @Input() public columnsHide: boolean; 
    @Input() public tableClass: string; 
    @Input() public width: string = '100%'; 

    constructor(private el: ElementRef) { 
    } 

    ngOnInit() { 
    Promise.all([ 
     System.import('script-loader!smartadmin-plugins/datatables-bundle/datatables.min.js'), 
    ]).then(()=>{ 
     this.render() 

    }) 
    } 

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


    let toolbar = ''; 
    if (options.buttons) 
     toolbar += 'B'; 
    if (this.paginationLength) 
     toolbar += 'l'; 
    if (this.columnsHide) 
     toolbar += 'C'; 

    if (typeof options.ajax === 'string') { 
     let url = options.ajax; 
     options.ajax = { 
     url: url, 
     // complete: function (xhr) { 
     // 
     // } 
     } 
    } 

    options = $.extend(options, { 

     "dom": "<'dt-toolbar'<'col-xs-12 col-sm-6'f><'col-sm-6 col-xs-12 hidden-xs text-right'" + toolbar + ">r>" + 
     "t" + 
     "<'dt-toolbar-footer'<'col-sm-6 col-xs-12 hidden-xs'i><'col-xs-12 col-sm-6'p>>", 
     oLanguage: { 
     "sSearch": "<span class='input-group-addon'><i class='glyphicon glyphicon-search'></i></span> ", 
     "sLengthMenu": "_MENU_" 
     }, 
     "autoWidth": false, 
     retrieve: true, 
     responsive: true, 
     initComplete: (settings, json)=> { 
     element.parent().find('.input-sm',).removeClass("input-sm").addClass('input-md'); 
     } 
    }); 

    const _dataTable = element.DataTable(options); 

    if (this.filter) { 
     // Apply the filter 
     element.on('keyup change', 'thead th input[type=text]', function() { 
     _dataTable 
      .column($(this).parent().index() + ':visible') 
      .search(this.value) 
      .draw(); 

     }); 
    } 


    if (!toolbar) { 
     element.parent().find(".dt-toolbar").append('<div class="text-right"><img src="assets/img/logo.png" alt="SmartAdmin" style="width: 111px; margin-top: 3px; margin-right: 10px;"></div>'); 
    } 

    if(this.detailsFormat){ 
     let format = this.detailsFormat 
     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(format(row.data())).show(); 
      tr.addClass('shown'); 
     } 
     }) 
    } 

    } 

} 

這裏是我的HTML模板使用它從另一個組件:

<div class="well"> 

    <h1>Store Items</h1> 
    <sa-datatable [options]="options" 
        [detailsFormat]="detailsFormat" 
        tableClass="display projects-table table table-striped table-bordered table-hover" 
        width="100%"> 
     <thead> 
     <tr> 
      <th data-hide="phone"></th> 
      <th data-hide="phone">Item</th> 
      <th data-class="expand"><i 
        class="fa fa-fw fa-user text-muted hidden-md hidden-sm hidden-xs"></i> 
       UUID 
      </th> 
      <th data-hide="phone"><i 
        class="fa fa-fw fa-phone text-muted hidden-md hidden-sm hidden-xs"></i> 
       Item ID 
      </th> 
      <th>Profit</th> 
      <th data-hide="phone,tablet"><i 
        class="fa fa-fw fa-map-marker txt-color-blue hidden-md hidden-sm hidden-xs"></i> 
       FTP Status 
      </th>    
     </tr> 
     </thead> 

    </sa-datatable> 


</div> 

這裏是我的組件:

import {Component, OnInit, ChangeDetectionStrategy, ElementRef} from '@angular/core'; 
import {FadeInTop} from "../../../shared/animations/fade-in-top.decorator"; 
declare var $: any; 
@FadeInTop() 
@Component({ 
    selector: 'store-items', 
    templateUrl: './store-items-datatable.html', 
    styleUrls: ['./store-items-datatable.css'], 
    changeDetection:ChangeDetectionStrategy.OnPush 
}) 
export class StoreItemsDatatable { 


    constructor() { 

    } 

    public options = {  
     "ajax": 'assets/roi/items.json', 
     "iDisplayLength": 15, 
     "columns": [ 
      { 
       "class": 'details-control', 
       orderable: false, 
       data: null, 
       defaultContent: '' 
      }, 
      //each line is a column 
      {data: "title"}, 
      {data: "uuid"}, 
      {data: "status"},    
     ], 
     "order": [[1, 'asc']] 
    } 

    public detailsFormat(d) { 

     return `<table cellpadding="5" cellspacing="0" border="0" class="table table-hover table-condensed"> 
        <tr> 
         <td style="width:100px">Actions:</td> 
         <td><a href='${d.generalInfo.link}' target="_blank">Go To Item</a> 

          <td>`+this.getActions(d)+`</td> 
        </tr>      
       </table>` 
    }  

    getActions(data) { 
     return ` 

      <div class="col-xs-12 col-sm-12 col-md-2 col-lg-2"> 
       <div class="modal-content"> 
        <div class="modal-header"> 
         <h4 class="modal-title">Upload Item to FTP</h4> 
        </div> 
        <div class="modal-body"> 
         <a class="btn btn-default btn-xs" id="uploadItemToFTP" rel="tooltip" data-placement="top" data-original-title="Upload Item to FTP" (click)='someMethod()'>Upload</a> 
        </div> 
       </div> 
      </div>`; 
    } 
} 

detailsFormat已通過html模板使用[detailsFormat]="detailsFormat"

問題是,當按下+ detailsFormat的方法返回額外的html內容,但按鈕的綁定不起作用,有沒有一種方法來再次呈現頁面後點擊+按鈕綁定到上傳按鈕將工作?

請求的最終結果是,(click)='someMethod()'將工作

回答

0

我們有相同的問題。 你有沒有找到解決方案?

我終於解決了它的做法,因爲detailsFormat只具有對html的引用,所以我創建了一個標籤並在標籤內插入了組件,並將div附加到數據表中。 這很簡單但並不容易。很棒!

在dataTable.component

,有一個輸入()detailComponent,你從你的HTML頁面發送爲[detailComponent] = 「細節」

,然後在它被調用detailsFormat做:

現在
row.child(detailComponent.location.nativeElement).show(); 

,具有文件中的detailFormats下面做:

public detailFormats() { 

    var componentFactory = this.resolver.resolveComponentFactory(ProjectDetailsComponent); 
    var newNode = document.createElement('div'); 
    newNode.id = 'detailHolder'; 
    var ref = componentFactory.create(this.injector, [], newNode); 
    this.app.attachView(ref.hostView); 
    return ref; 

} 

「YourComponent」是具有要顯示在用戶CLIC你的HTML組件ks +按鈕。

,如果你想將數據傳遞到組件中,前行線上的DataTable.component,添加:

(detailComponent.instance).model = row.data(); 

類似的做法: https://angular.io/guide/dynamic-component-loader