angular.js - angular2中异步ngfor渲染数据的bug?
仅有的幸福
仅有的幸福 2017-05-15 17:03:30
0
1
644

我正在使用angular2做一个表格分页

page.component.ts

export class Interface { currentPage:Number; errorMessage:string; items:{}; mode = 'Observable'; shortPages:Promise; 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 = 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 = 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 { 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

{{number}}

但是我在模板中加入*ngIf模板判断后:

{{number}}

渲染成了这样,多出了一个内容为空的a标签

这是什么原因?如何解决?

仅有的幸福
仅有的幸福

reply all (1)
阿神

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.

    Latest Downloads
    More>
    Web Effects
    Website Source Code
    Website Materials
    Front End Template
    About us Disclaimer Sitemap
    php.cn:Public welfare online PHP training,Help PHP learners grow quickly!