ngx-datatable столбцы не рендеринг - угловой

Поэтому я пытаюсь создать динамический набор данных с помощью плавательного канала ngx-datatable, Мои данные поступают из бэкэнда, и я могу видеть данные на своей консоли. Немногие из столбцов отображаются в таблице, а некоторые из них - нет. Я не могу выяснить, почему некоторые столбцы не отображаются. Любая помощь с благодарностью.

Ниже приведен один из данных строки

JSON

clientname , id, drugsource, edit рендерится, но medication_name , mapping_comment , strength не является.

HTML:

<ngx-datatable 
class="material"
[headerHeight]="50"

[columnMode]="'force'"
[footerHeight]="50"
[rowHeight]="'auto'"
[rows]="rows"
[columns]="columns"
[loadingIndicator]="loadingIndicator"
[externalPaging]="true"
[count]="page.count"
[offset]="page.pageNumber"
[limit]="page.size"
(page)='setPage($event)'
>


<ngx-datatable-column name="clientname">
  <ng-template ngx-datatable-cell-template let-value="value">
    {{value}}
  </ng-template>
</ngx-datatable-column>

<ngx-datatable-column name="medication_name">
  <ng-template ngx-datatable-cell-template let-value="value">
    {{value}}
  </ng-template>
</ngx-datatable-column>

<ngx-datatable-column name="edit">
  <ng-template ngx-datatable-cell-template let-rowIndex="rowIndex" let-value="value" let-row="row">
    <span
      title="Double click to edit"
      (dblclick)="editing[rowIndex + '-edit'] = true"
      *ngIf="!editing[rowIndex + '-edit']">
      {{value}}
    </span>
    <md-input-container *ngIf="editing[rowIndex+ '-edit']" >
          <input mdInput autofocus   placeholder="Search drug" [mdAutocomplete]="auto" [formControl]="drug" showPanel="false">
        </md-input-container>

        <md-autocomplete #auto="mdAutocomplete" [displayWith]="displayFn" >

          <md-option *ngFor="let drug of filteredDrugs " [value]="drug" style="border-bottom: 1px solid #3f51b5; line-height : 30px ; height :10%">
            <span style="font-size : 12px;font-family : verdana">
                <strong>Drugname </strong> : {{ drug.drugname}} <br/>
                <strong> NDC </strong> : {{ drug.ndc}} <br/>
                <strong> Strength </strong> : {{ drug.strength}} <br/>
            </span>  
          </md-option>
        </md-autocomplete>

  </ng-template>
</ngx-datatable-column>
</ngx-datatable>

TS:

import { Component, OnInit, Input, ViewEncapsulation } from '@angular/core';
import { GetData } from '../main/main.service';
import { Observable } from 'rxjs/Observable';
import { FormControl } from '@angular/forms';

@Component({
  selector: 'app-data-table-new',
  templateUrl: './data-table-new.component.html',
  styleUrls: ['./data-table-new.component.css'],
  encapsulation: ViewEncapsulation.None
})
export class DataTableNewComponent {
  @Input() filter: string;
  page : any = { 
    count : 0,
    pageNumber : 1,
    offset : 0
  };
  editing = {};
  rows = [];

  drug: FormControl;
  drugList = [];
  filteredDrugs: Observable<any>;
  id: number;
  drugDetails: any;

  loadingIndicator: boolean = true;

  columns = [];

  constructor(private getdata: GetData) {
    this.fetch((data) => {
      console.log("constructor walu ", data);
      this.rows = data;
    });
    this.drug = new FormControl();
  }

  fetch(cb) {
    // const req = new XMLHttpRequest();
    // req.open('GET', `assets/data/company.json`);

    // req.onload = () => {
    //   cb(JSON.parse(req.response));
    // };

    // req.send();
    console.log("fetch is called")
    this.getdata.getDrugDataForClient(0, 20).subscribe((data) => { 
      console.log(data); 
      data.columns.forEach((ele,index) => {
        this.columns.push({
          prop : ele,
          name : ele
        })
      });
      console.log("columns are= > ",this.columns);
      // this.columns= data.columns ;
      this.page.count =data.count ;
      this.rows = data.data;
      this.loadingIndicator = false;
      return data ;
    });
  }

  updateValue(event, cell, rowIndex) {

    /* change logic here
    console.log('inline editing rowIndex', rowIndex)
    this.editing[rowIndex + '-' + cell] = false;
    this.rows[rowIndex][cell] = event.target.value;
    this.rows = [...this.rows];
    console.log('UPDATED!', this.rows[rowIndex][cell]);
    */
  }

  ngOnInit() {
    this.drug.valueChanges
      .subscribe((drugname) => this.getdata.getDataForAutoComplete(drugname)
        .subscribe(resp => { this.filteredDrugs = resp.json() }));
  }

  displayFn(drug) {
    console.log(drug);
    this.drugDetails = drug;
    return drug == null ? drug : drug.drugname;
  }


  setPage(pageInfo){
    this.page["pageNumber"] = pageInfo.offset;
    // this.serverResultsService.getResults(this.page).subscribe(pagedData => {
    //   this.page = pagedData.page;
    //   this.rows = pagedData.data;
    // });
    this.getdata.getDrugDataForClient(pageInfo.offset, 20).subscribe((data) => { 
      console.log(data); this.page["count"] =data.count ;this.rows = data.data; this.loadingIndicator = false; return data 
    });
  }


}

1 ответ

Насколько я знаю; определение шаблонов ngx-datatable-column означает, что вы указываете ngx-datatable для отображения столбцов в соответствии с определенными шаблонами, а не для автоматического отображения столбцов. Таким образом, удаление тегов ngx-datatable-column изнутри ngx-datatable и использование входных данных столбца cellTemplate & headerTemplate должно быть правильным решением для вас.

data.columns.forEach((ele,index) => {
    this.columns.push({
        prop : ele,
        name : ele,
        cellTemplate : ...,
        headerTemplate : ...
    });
});
Другие вопросы по тегам