首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >动态地将步骤添加到mat步进器并导航到它抛出超出界限的错误。

动态地将步骤添加到mat步进器并导航到它抛出超出界限的错误。
EN

Stack Overflow用户
提问于 2019-09-18 16:37:49
回答 1查看 1.7K关注 0票数 3

我正在使用一个简单的mat步进器,其中的步骤是使用*ngFor从数组中生成的。

在呈现步骤后,我想动态地向显示中添加一个步骤,然后立即以编程方式导航到它,

动态添加这些步骤很好--导航部分是一个问题,因为它导致了一个异常:"Error: cdkStepper:无法将超出范围的值分配给selectedIndex“,尽管分配的索引应该在基于传递给组件的步骤的范围内。

为了说明这个问题,简化了示例(超时只是异步行为的占位符,会导致添加额外的步骤)。

代码语言:javascript
复制
steps = ['step1', 'step2'];
selectedIndex = 1;

ngOnInit() {
  setTimeout(() => {
    this.steps.push('step3');
    this.selectedIndex = 2;
  });
}
代码语言:javascript
复制
<mat-stepper [selectedIndex]="selectedIndex">
  <mat-step *ngFor="let step of steps">
    {{step}}
  </mat-step>
</mat-stepper>

我们该怎么解决这个问题呢?

完整示例:https://stackblitz.com/edit/angular-cdafd9?file=app%2Fstepper-overview-example.ts

EN

回答 1

Stack Overflow用户

发布于 2019-09-18 17:06:38

似乎步进需要一点初始化。如果在setTimeout之前添加这个步骤,它就会运行得很好。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57997291

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档