在 Angular 6 中使用 ng2-smart-table 创建服务器端分页
Creating server side pagination with ng2-smart-table in Angular 6
我正在尝试使用组件 <ng2-smart-table>
。我确实做到了,但是我需要在用户点击页面或列进行排序后刷新数据,有没有办法捕获这些事件并刷新数据?
table.component.html
<ng2-smart-table
[settings]="settings"
[source]="characters">
</ng2-smart-table>
table.service.ts
import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
@Injectable()
export class TableService {
constructor(private http: HttpClient) { }
url = 'http://localhost:4000';
getCharacters() {
return this
.http
.get(`${this.url}/characters`);
}
}
table.interface.ts
export interface Table {
ticket: String;
title: String;
state: String;
owner: String;
age: String;
priority: String;
}
table.component.ts
import { Component, OnInit } from '@angular/core';
import { TableService } from './table.service';
import { Table } from './table.interface';
import { Observable } from 'rxjs';
@Component({
selector: 'app-table',
templateUrl: './table.component.html',
styleUrls: ['./table.component.scss']
})
export class TableComponent implements OnInit {
characters: Table[];
settings = {
columns: {
ticket: {
title: 'Ticket',
filter: false
},
title: {
title: 'Title',
filter: false
},
state: {
title: 'State',
filter: false
},
owner:{
title: 'Owner',
filter: false
},
age:{
title: 'Age',
filter: false
},
priority:{
title: 'Priority',
filter: false
}
},
actions:{
columnTitle: '',
add: false,
edit: false,
delete: false
}
};
constructor(private tservice: TableService) { }
ngOnInit() {
this
.tservice
.getCharacters()
.subscribe((data: Table[]) => {
this.characters = data;
});
}
}
parent.component.ts
import { Component, OnInit } from '@angular/core';
import { TableComponent } from '../../utils/table/table.component';
@Component({
selector: 'app-ticket-item-list',
templateUrl: './ticket-item-list.component.html',
styleUrls: ['./ticket-item-list.component.scss']
})
export class TicketItemListComponent implements OnInit {
pagination = {
TotalItems: 100,
CurrentPage: 1,
PageSize: 10,
TotalPageLinkButtons: 5,
RowsPerPageOptions: [10, 20, 30, 50, 100]
};
/* Paging Component metod */
myChanges(event) {
this.pagination.CurrentPage = event.currentPage;
this.pagination.TotalItems = event.totalItems;
this.pagination.PageSize = event.pageSize;
this.pagination.TotalPageLinkButtons = event.totalPageLinkButtons;
}
constructor() { }
ngOnInit() {
}
}
parent.component.html
<app-table></app-table>
您可以使用 ng2-smart-table LocalDataSource 进行过滤,设置过滤器添加过滤器等。因此您可以将服务结果存储在 LocalDataSource 对象中。在你的初始化中是这样的:
this.characters = new LocalDataSource(tableService.getCharacters());
分页使用setPaging
喜欢
this.YourlocalDataSource.setPaging(1, 10, true);
1
是页面,
10
是每页的行数,
true
强制渲染页面
我正在尝试使用组件 <ng2-smart-table>
。我确实做到了,但是我需要在用户点击页面或列进行排序后刷新数据,有没有办法捕获这些事件并刷新数据?
table.component.html
<ng2-smart-table
[settings]="settings"
[source]="characters">
</ng2-smart-table>
table.service.ts
import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
@Injectable()
export class TableService {
constructor(private http: HttpClient) { }
url = 'http://localhost:4000';
getCharacters() {
return this
.http
.get(`${this.url}/characters`);
}
}
table.interface.ts
export interface Table {
ticket: String;
title: String;
state: String;
owner: String;
age: String;
priority: String;
}
table.component.ts
import { Component, OnInit } from '@angular/core';
import { TableService } from './table.service';
import { Table } from './table.interface';
import { Observable } from 'rxjs';
@Component({
selector: 'app-table',
templateUrl: './table.component.html',
styleUrls: ['./table.component.scss']
})
export class TableComponent implements OnInit {
characters: Table[];
settings = {
columns: {
ticket: {
title: 'Ticket',
filter: false
},
title: {
title: 'Title',
filter: false
},
state: {
title: 'State',
filter: false
},
owner:{
title: 'Owner',
filter: false
},
age:{
title: 'Age',
filter: false
},
priority:{
title: 'Priority',
filter: false
}
},
actions:{
columnTitle: '',
add: false,
edit: false,
delete: false
}
};
constructor(private tservice: TableService) { }
ngOnInit() {
this
.tservice
.getCharacters()
.subscribe((data: Table[]) => {
this.characters = data;
});
}
}
parent.component.ts
import { Component, OnInit } from '@angular/core';
import { TableComponent } from '../../utils/table/table.component';
@Component({
selector: 'app-ticket-item-list',
templateUrl: './ticket-item-list.component.html',
styleUrls: ['./ticket-item-list.component.scss']
})
export class TicketItemListComponent implements OnInit {
pagination = {
TotalItems: 100,
CurrentPage: 1,
PageSize: 10,
TotalPageLinkButtons: 5,
RowsPerPageOptions: [10, 20, 30, 50, 100]
};
/* Paging Component metod */
myChanges(event) {
this.pagination.CurrentPage = event.currentPage;
this.pagination.TotalItems = event.totalItems;
this.pagination.PageSize = event.pageSize;
this.pagination.TotalPageLinkButtons = event.totalPageLinkButtons;
}
constructor() { }
ngOnInit() {
}
}
parent.component.html
<app-table></app-table>
您可以使用 ng2-smart-table LocalDataSource 进行过滤,设置过滤器添加过滤器等。因此您可以将服务结果存储在 LocalDataSource 对象中。在你的初始化中是这样的: this.characters = new LocalDataSource(tableService.getCharacters());
分页使用setPaging
喜欢
this.YourlocalDataSource.setPaging(1, 10, true);
1
是页面,
10
是每页的行数,
true
强制渲染页面