【问题标题】:Angular 2 - Kendo UI grid. Paging not workingAngular 2 - 剑道 UI 网格。分页不起作用
【发布时间】:2017-03-05 05:51:18
【问题描述】:

我正在 Visual Studio 中使用 Kendo 网格控件构建 Angular 2 应用程序。我已经编写了分页功能的代码,但它似乎不起作用。有人可以帮忙吗?

risk-list.component.ts

import { Component, OnInit } from '@angular/core';
import { Risk } from './risk';
import { RiskService } from './risk.service';
import { GridModule, GridDataResult, PageChangeEvent, SortDescriptor, orderBy} 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 sort: SortDescriptor[] = [];
    private data: any[];
    private pageSize: number = 10;
    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();
    }

    protected sortChange(sort: SortDescriptor[]): void {
        this.sort = sort;
        this.loadRisks();
    }


    private loadRisks(): void {
        this.gridView = {
            data: this.data.slice(this.skip, this.skip + this.pageSize), 
           // data: orderBy(this.risks, this.sort),
            total: this.data.length
        };
    }

    getRisks(): void {
        this._riskService.getRisks().then(risks => this.risks = risks);

    }

    ngOnInit(): void {
        this.getRisks();
    }
};

risk-list.component.html

<kendo-grid [data]="risks"
            [skip]="skip"
            [pageSize]="pageSize"
            [scrollable]="'virtual'"
            [rowHeight]="36"
            [height]="300"
            (pageChange)="pageChange($event)"
            [pageable]="true"   
            [sortable]="{ mode: 'multiple' }"
            [sort]="sort"
            (sortChange)="sortChange($event)">
    <kendo-grid-column field="reference" title="Reference" width="120">
    </kendo-grid-column>
    <kendo-grid-column field="insuredName" title="Insured Name" width="120">
    </kendo-grid-column>
    <kendo-grid-column field="inceptionDate" title="Inception Date" width="120">
    </kendo-grid-column>
    <kendo-grid-column field="riskType" title="Risk Type" width="120">
    </kendo-grid-column>
    <kendo-grid-column field="status" title="Indication" width="120">
    </kendo-grid-column>
    <kendo-grid-column field="grossPremium" title="Gross Premium" width="120">
    </kendo-grid-column>
    <kendo-grid-column field="allocatedTo" title="Allocated To" width="120">
    </kendo-grid-column>
    <kendo-grid-column field="allocatedCompany" title="Allocated Company" width="120">
    </kendo-grid-column>
    <kendo-grid-column field="Discontinued" width="100">
        <template kendoCellTemplate let-dataItem>
            <input type="checkbox" [checked]="dataItem.Discontinued" disabled />
        </template>
    </kendo-grid-column>
</kendo-grid>

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

}

【问题讨论】:

    标签: angular kendo-grid kendo-ui-angular2


    【解决方案1】:

    我认为您没有将风险数据分配给 this.data 数组,并且您正在尝试使用 this.data.slice(this.skip, this.skip + this.pageSize) 将为空值

    试试下面的代码

     export class RiskListComponent implements OnInit {
    private gridView: GridDataResult;
    private sort: SortDescriptor[] = [];
    private data: any[];
    private pageSize: number = 10;
    private skip: number = 0;
    title = 'Risk List';
    risks: Risk[];
    risks1: Risk[];
    view;
    
    constructor(private _riskService: RiskService) {
        this.data = [];
        this.getRisks();
        this.loadRisks();
     }
    
    protected pageChange(event: PageChangeEvent): void {
        this.skip = event.skip;
        this.loadRisks();
    }
    
    protected sortChange(sort: SortDescriptor[]): void {
        this.sort = sort;
        this.loadRisks();
    }
    
    
    private loadRisks(): void {
        this.view= {
            data: this.risks1.slice(this.skip, this.skip + this.pageSize), 
           // data: orderBy(this.risks, this.sort),
            total: this.risks1.length
        };
    }
    
    getRisks(): void {
        this._riskService.getRisks().then(risks => this.risks1 = risks);
    
    }
    
    ngOnInit(): void {
        this.getRisks();
    }
    

    };

    在 Risk-listcomponent.html 而不是风险中,将视图分配给 [数据]

    <kendo-grid [data]="view"
            [skip]="skip"
      ....
    

    【讨论】:

    • 我在哪里分配它?
    • 我试过上面的代码。我收到错误无法读取未定义的属性“切片”
    • 数据是否在 getRisks() 方法中分配给 this.risks1?
    • 我拉古。我收到一条错误消息“类型 '{data:Risk[];total:number;}' 不可分配给类型 Risk[]。它是编译时错误
    • 我尝试了上面的步骤,但它不起作用。我在上面的帖子中添加了 riskservice 的代码。如果我设置 risk1.slice 然后我收到消息说无法读取未定义的属性切片
    【解决方案2】:

    您不能在 KendoGrid 中同时进行虚拟滚动分页

    一旦启用[scrollable]="'virtual'",它将隐藏分页。

    如果你正在寻找分页,那么删除[scrollable]="'virtual'"

    您可以参考this

    【讨论】:

    • 当我按照您的建议进行操作时,我可以看到分页和滚动条,但分页似乎不起作用。所以当我点击下一组时,它似乎没有移动记录并显示前 10 条记录。
    猜你喜欢
    • 2023-03-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-11-25
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多