0
私は角度2+に初めて慣れて、最初のアプリを開発しようとしています。ここに私の問題がある: 私は材料の表に私のデモデータを表示しようとしている:の接続機能は起動しません
htmlファイル:
import { Component, OnInit } from '@angular/core';
import { DataSource } from '@angular/cdk/collections';
import { Observable } from 'rxjs/Observable';
import { GridViewService } from './grid-view.service';
import { Http, Response } from '@angular/http';
import { IGridView } from './grid-view.interface';
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/do';
import 'rxjs/add/operator/catch';
@Component({
templateUrl: './grid-view.component.html',
styleUrls: ['./grid-view.component.css'],
providers: [GridViewService]
})
export class GridViewComponent {
pageTitle: string = 'Products List';
listFilter: string = '';
errorMessage: string;
imageWidth: number = 50;
imageMargin: number = 2;
gridViewList :DataSourceComponent;
displayedColumns = ['productId', 'productName', 'productCode',
'releaseDate', 'Price'];
constructor(private _gridViewService: GridViewService) {
}
}
class DataSourceComponent extends DataSource<any> {
private _productUrl = 'assets/data.json';
constructor(private _http :Http) {
super();
}
connect(): Observable<any> {
return this._http.get(this._productUrl)
.map((response: Response) => <IGridView[]>response.json())
.do(data => console.log('All: ' + JSON.stringify(data)))
.catch(this.handleError);
}
disconnect() { }
private handleError(error: Response) {
console.error(error);
return Observable.throw(error.json().error || 'Server error');
}
}
:ここ
<div class='panel panel-primary'>
<div class='panel-heading'>
{{pageTitle}}
</div>
<div class='panel-body'>
<div class="example-container mat-elevation-z8" >
<cdk-table #table [dataSource]="gridViewList" class="example-table">
<ng-container cdkColumnDef="productId">
<cdk-header-cell *cdkHeaderCellDef class="example-header-cell"> ID </cdk-header-cell>
<cdk-cell *cdkCellDef="let row" class="example-cell"> {{row.productId}} </cdk-cell>
</ng-container>
<ng-container cdkColumnDef="productName">
<cdk-header-cell *cdkHeaderCellDef class="example-header-cell"> name </cdk-header-cell>
<cdk-cell *cdkCellDef="let row" class="example-cell"> {{row.productName}} </cdk-cell>
</ng-container>
<ng-container cdkColumnDef="productCode">
<cdk-header-cell *cdkHeaderCellDef class="example-header-cell"> Code </cdk-header-cell>
<cdk-cell *cdkCellDef="let row" class="example-cell"> {{row.productCode}} </cdk-cell>
</ng-container>
<ng-container cdkColumnDef="releaseDate">
<cdk-header-cell *cdkHeaderCellDef class="example-header-cell">Available</cdk-header-cell>
<cdk-cell *cdkCellDef="let row" class="example-cell">
{{row.releaseDate}}
</cdk-cell>
</ng-container>
<ng-container cdkColumnDef="Price">
<cdk-header-cell *cdkHeaderCellDef class="example-header-cell">Price</cdk-header-cell>
<cdk-cell *cdkCellDef="let row" class="example-cell">
{{row.price}}
</cdk-cell>
</ng-container>
<cdk-header-row *cdkHeaderRowDef="displayedColumns" class="example-header-row"></cdk-header-row>
<cdk-row *cdkRowDef="let row; columns: displayedColumns;" class="example-row"></cdk-row>
</cdk-table>
</div>
</div>
とは、私のTSファイルであります
問題は、テーブルがレンダリングされておらず、ページロード時にトリガーしない接続機能です!
誰でもここに、私を助けることができますか?
コンストラクタの引数にはどうすればよいですか? –
GridViewComponentに 'private _http:Http'を注入し、' this._http'をコンストラクタに渡します。更新された回答をご覧ください。 – Sibin