我在使用 Angular 时遇到了这个烦人的问题:我通过添加到provides
页面中来覆盖步进器图标:
provide: STEPPER_GLOBAL_OPTIONS, useValue: {displayDefaultIndicatorType: false, showError: true}
这是 HTML 页面(只是一小部分,复制/粘贴了 7 个元素):
<mat-horizontal-stepper>
<!-- AREA -->
<mat-step label="Step 1" state="area">
<p>Put down your phones</p>
<div>
<button mat-button matStepperNext>Next</button>
</div>
</mat-step>
<!-- QUESTION -->
<mat-step label="Step 2" state="question">
<p>Socialize with each other</p>
<div>
<button mat-button matStepperPrevious>Back</button>
<button mat-button matStepperNext>Next</button>
</div>
</mat-step>
<!-- MODE -->
<mat-step label="Step 3" state="mode">
<p>Socialize with each other</p>
<div>
<button mat-button matStepperPrevious>Back</button>
<button mat-button matStepperNext>Next</button>
</div>
</mat-step>
...
<!-- Icon overrides -->
<!-- AREA -->
<ng-template matStepperIcon="area">
<mat-icon>gavel</mat-icon>
</ng-template>
<!-- QUESTION -->
<ng-template matStepperIcon="question">
<mat-icon>contact_support</mat-icon>
</ng-template>
<!-- MODE -->
<ng-template matStepperIcon="mode">
<mat-icon>forum</mat-icon>
</ng-template>
...
如您所见,这只是您可以在 Angular 9文档中找到的示例
好吧,现在让我用几个图像来介绍问题:
看看圆圈,他们应该有自己的图标(gavel、constact_support、forum)。但是当我在其中一个步骤上时,它会用另一个图标替换图标,准确地说是create icon。
现在,如果我回到第二步,在圆圈中生成正确的图标,而不会出现这种烦人的覆盖:
我已经尝试过:
[completed]=false
在组件上设置<mat-step>
,但它只是将检查图标删除到以前的圆圈中- 覆盖图标:
<ng-template matStepperIcon="edit">
<mat-icon>gavel</mat-icon>
</ng-template>
但它没有用,因为它只是覆盖了图标,所以问题仍然存在。我也试图留下<mat-icon></mat-icon>
空白,但当然它只会在圆圈中留下一个空白图标。
我想要实现的是绕过这种“自动覆盖”。任何想法?