Тип ‘void’ не может быть присвоен типу ‘any[]’

#angular #kendo-grid

#угловой #kendo-grid

Вопрос:

Я получаю ошибку в следующей строке кода конструктора

 this.data = this.getRisks(); . 
  

Ошибка

Тип ‘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();
    }
};
  

risk.service.ts

 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);
    }

}
  

Ответ №1:

Поскольку getRisks() ничего не возвращает, просто вызовите его, и он установит this.data

 constructor(private _riskService: RiskService) {
    this.getRisks();
    this.loadRisks();
 }
  

Вы можете установить, this.data = [] если вам нужно, чтобы он был определен до того, как данные будут доступны.