I am using angular2 to make a table pagination
page.component.ts
export class Interface {
currentPage:Number;
errorMessage:string;
items:{};
mode = 'Observable';
shortPages:Promise<any>;
private resolve:Function = null;
constructor(private interfaceService:InterfaceService, params:RouteParams) {
this.currentPage = parseInt(params.get('page'));
this.shortPages = new Promise((resolve, reject) => {
this.resolve = resolve;
});
}
ngOnInit() {
this.getDatas(this.currentPage);
}
getDatas(page) {
/*this.interfaceService.getDatas()
.subscribe(
datas => this.items = datas,
error => this.errorMessage = <any>error);*/
this.items = this.interfaceService.getDatas(page)
.subscribe(
items => {
this.items = items;
if (items.page_total_cnts <= 7) {
let arr = [1,2,3,4,5];//测试用
for (let i = 2; i < items.page_total_cnts; i++) {
arr.push(i);
}
this.resolve(arr);
console.log(this.shortPages);
}
console.log(this.items)
},
error => this.errorMessage = <any>error);
}
}
interface.service.ts
export class InterfaceService {
constructor (private jsonp:Jsonp) {}
private dataUrl = 'http://192.168.1.163:8009/testdata/read-server-api-testdata/'; // URL to web API
getDatas (page): Observable<any> {
let params = new URLSearchParams();
params.set('page_idx', page); // the user's search value
params.set('callback', 'JSONP_CALLBACK');
return this.jsonp.get(this.dataUrl, { search: params })
.map(res => res.json());
//return Datas
}
/*private extractData(res: Response) {
let body = res.json();
return body.data || { };
}*/
private handleError (error: any) {
// In a real world app, we might use a remote logging infrastructure
// We'd also dig deeper into the error to get a better message
let errMsg = (error.message) ? error.message :
error.status ? `${error.status} - ${error.statusText}` : 'Server error';
console.error(errMsg); // log to console instead
return Observable.throw(errMsg);
}
}
template.html
<a *ngFor="let number of shortPages|async" [routerLink]="['Interface',{page: number}]" class="short">{{number}}</a>
But after I added *ngIf template judgment to the template:
<a *ngIf="true或者任何其他判断条件" *ngFor="let number of shortPages|async" [routerLink]="['Interface',{page: number}]" class="short">{{number}}</a>
Rendered like this, there is an extra a tag with empty content
What is the reason? How to solve it?
Forget it, I'll answer it myself. After debugging for a long time, it seems that there is a bug in NG2 when ng-if and ng-for are used together on the same element, so I can only add a template element in the outer layer.