国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

angular.js - angular2中異步ngfor渲染數據的bug?

瀏覽:153日期:2024-10-01 17:25:45

問題描述

我正在使用angular2做一個表格分頁

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 valueparams.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 messagelet errMsg = (error.message) ? error.message : error.status ? `${error.status} - ${error.statusText}` : ’Server error’;console.error(errMsg); // log to console insteadreturn Observable.throw(errMsg); }}

template.html

<a *ngFor='let number of shortPages|async' [routerLink]='[’Interface’,{page: number}]' class='short'>{{number}}</a>

angular.js - angular2中異步ngfor渲染數據的bug?

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

<a *ngIf='true或者任何其他判斷條件' *ngFor='let number of shortPages|async' [routerLink]='[’Interface’,{page: number}]' class='short'>{{number}}</a>

渲染成了這樣,多出了一個內容為空的a標簽

angular.js - angular2中異步ngfor渲染數據的bug?

這是什么原因?如何解決?

問題解答

回答1:

算了我自己來回答吧,調試半天,NG2里面貌似ng-if和ng-for一起用在同一個元素上有BUG,只能在外層加個templat元素了。

相關文章:
主站蜘蛛池模板: 青铜峡市| 汉中市| 宝坻区| 太康县| 正定县| 射洪县| 璧山县| 岑巩县| 天峻县| 毕节市| 芮城县| 惠来县| 高碑店市| 邢台市| 大兴区| 普定县| 建平县| 太原市| 锦州市| 望城县| 卢氏县| 临沭县| 额尔古纳市| 南雄市| 河源市| 承德县| 旬邑县| 县级市| 南华县| 登封市| 阿克苏市| 柳江县| 乌鲁木齐县| 邮箱| 牡丹江市| 乌鲁木齐市| 东明县| 应城市| 潮安县| 砀山县| 怀仁县|