Tom*_*Tom 5 kendo-grid angular
我在构造函数代码的以下行出现错误
this.data = this.getRisks(); .
Run Code Online (Sandbox Code Playgroud)
错误是
类型“ void”不可分配给类型“ any []”。
有人可以告诉我如何分配它。
import { Component, OnInit } from '@angular/core';
import { Risk } from './risk';
import { RiskService } from './risk.service';
import { GridModule, GridDataResult, PageChangeEvent } from '@progress/kendo-angular-grid';
@Component({
moduleId: module.id,
selector: 'rm-risks',
templateUrl: '/app/risk-list.component.html',
providers: [RiskService]
})
export class RiskListComponent implements OnInit {
private gridView: GridDataResult;
private data: any[];
private pageSize: number = 50;
private skip: number = 0;
title = 'Risk List';
risks: Risk[];
constructor(private _riskService: RiskService) {
this.data = this.getRisks();
this.loadRisks();
}
protected pageChange(event: PageChangeEvent): void {
this.skip = event.skip;
this.loadRisks();
}
private loadRisks(): void {
this.gridView = {
data: this.data.slice(this.skip, this.skip + this.pageSize),
total: this.data.length
};
}
getRisks(): void {
this._riskService.getRisks().then(risks => this.risks = risks);
}
ngOnInit(): void {
this.getRisks();
}
};
Run Code Online (Sandbox Code Playgroud)
风险服务
import { Injectable } from '@angular/core';
import { Risk } from './risk';
import { Risks } from './mock-risk';
import { Http, Response } from '@angular/http';
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/observable/from';
@Injectable()
export class RiskService {
getRisks(): Promise<Risk[]> {
return Promise.resolve(Risks);
}
}
Run Code Online (Sandbox Code Playgroud)
由于getRisks()不返回任何内容,只需调用它即可设置this.data
constructor(private _riskService: RiskService) {
this.getRisks();
this.loadRisks();
}
Run Code Online (Sandbox Code Playgroud)
您可以设置this.data = []是否需要在数据可用之前定义它。
| 归档时间: |
|
| 查看次数: |
13167 次 |
| 最近记录: |