当尝试使用ng build --prod --output-path <my_destination_path>
命令构建我的Angular项目时,我得到的错误很少,如下所示:
ERROR in src/app/products/product-edit/product-edit.component.html(190,10): : Property 'length' does not exist on type 'AbstractControl'.
模板product-edit.component.html:(错误在第一行)
<div *ngIf="productForm.get('seasons').length>0; else infoTextNoSeasons" formArrayName="seasons">
<div class="row" *ngFor="let seasonCtrl of productForm.get('seasons').controls; let i = index"
[formGroupName]="i">
<div [class.col-xs-10]="i!=0">
<div [class.row]="i!=0">
<div class="form-group col-sm-12">
<label class="sr-only" for="season">Season</label>
...
既然应用程序使用ng serve
运行得很好,我不明白为什么Angular不能构建它。
发布于 2018-03-04 13:09:33
当使用--prod标志时,您使用的是AOT编译器。
与在浏览器中运行并将模板编译为JavaScript的即时编译器不同,AOT编译器在构建期间运行,将模板编译为TypeScript,然后将TypeScript编译为JavaScript。
因此应用了TypeScript类型检查,这允许在编译时而不是运行时发现模板中的错误。
错误消息告诉您出了什么问题:您试图从AbstractControl访问length
属性,但AbstractControl没有这样的属性。length
只存在于FormArray中,但TypeScript不能知道AbstractControl是FormArray。因此,在组件中添加一个使用类型断言并返回长度的方法。
https://stackoverflow.com/questions/49095520
复制相似问题