我用從JSON填充DataTable的數據時遇到問題。我無法訪問其中一個數組的JSON字段。目前,它返回[object Object]
而不是正確的數據。我在ngOnInit
組件中動態創建cols。PrimeNG DataTable填寫數據問題
簡化的代碼:
Vehicle.component.ts
export class VehicleComponent implements OnInit {
cols: any[];
cols2: any[];
ngOnInit() {
this.cols = [
{ field: 'vehicle_id', header: "Vehicle ID" },
{ field: 'dallassettings', header: 'Dallas settings' },
{ field: 'dallasupdated', header: 'Dallas updated' },
{ field: 'dallas_list', header: 'Dallas list' }
];
this.cols2 = [
{ field: 'number', header: 'Number' },
{ field: 'auth', header: 'Auth' },
{ field: 'dallas_list', header: 'Dallas list' }
]; //testing out other possibilities
}
public vehicles: GeneralVehicle[];
constructor(private vehicleService: VehicleService, private router: Router) {
this.vehicleService.getVehicle().subscribe(vehicle => {
this.vehicles = vehicle;
});
}
interface GeneralVehicle {
status: number;
dallases: Vehicle[];
}
interface Vehicle {
vehicle_id: number;
dallassettings: string;
dallasupdated: string;
dallas_list: DallasList[];
}
interface DallasList {
number: number;
auth: number;
}
Vehicle.service.ts
export class VehicleService {
private defUrl = 'dummy.url';
constructor(private http: Http) { }
getVehicle(username?: string, password?: string) {
const url = (!username || !password) ? this.defUrl : 'dummy.url' + username + '/' + Md5.hashStr(password);
return this.http.get(url)
.map(res => res.json());
vehicle.html
<div *ngIf="vehicles">
<p-dataTable [value]="vehicles.dallases">
<p-column *ngFor="let col of cols" [field]="col.field" [header]="col.header"></p-column>
</p-dataTable>
</div>
<!--Testig out other possibilities-->
<div *ngIf="vehicles">
<p-dataTable [value]="vehicles.dallas_list">
<p-column *ngFor="let col2 of cols2" [field]="col2.field" [header]="col2.header"></p-column>
</p-dataTable>
</div>
當我嘗試從dallas_list
陣列獲得number
和auth
:
這是JSON的樣子:
{
"status": 0,
"dallases": [{
"vehicle_id": 17954,
"dallassettings": "3",
"dallasupdated": "False",
"dallas_list": [{
"number": 666111222,
"auth": 3
}, {
"number": 666777888,
"auth": 4
}, {
"number": 123454321,
"auth": 4
}]
}
}
至於你可以看到,我只對dallases
字段中的數據感興趣。
預期cols輸出:vehicle_id,dallassettings,dallasupdated,number,auth。
該解決方案的工作原理,但你有任何想法如何合併成一個表?相乘的數字可以是用分號分隔的一行。我想我不能在''標記內使用'[value] =「vehicles.dallases [0] .dallas_list」',所以它很難讓它工作。你認爲'RowGroup'會以某種方式解決這個問題嗎? –
Haseoh
檢查鏈接https://www.primefaces.org/primeng/#/datatable/rowexpansion – Vignesh