如何使用角钢和角钢将步进机从一步移动到第二步

时间:2019-04-26 10:40:25

标签: angular angular7 angular-material-stepper mat-stepper

我有2-4步表格。我已经分离出如下结构形式。  首先是auth文件夹,然后是register文件夹。在此register-register.tsregister.html下。在register.html下,我实现了mat stepper,如下所示:

 <mat-horizontal-stepper [linear]="isLinear" #stepper>

                    <mat-step [stepControl]="firstFormGroup">
                      <form [formGroup]="firstFormGroup">
                        <ng-template matStepLabel> step 1 </ng-template>
                        <mat-card class="example-card">
                                <mat-card-header>
                                    <div mat-card-avatar class="example-header-image"></div>
                                    <mat-card-title>step 1</mat-card-title>
                                </mat-card-header>
                                <mat-card-content>
                                        <kt-stepone></kt-stepone>
                                </mat-card-content>

                        </mat-card>

                        <div>

                        </div>
                      </form>
                    </mat-step>

                    <mat-step [stepControl]="secondFormGroup">
                      <form [formGroup]="secondFormGroup">
                        <ng-template matStepLabel> step 2 </ng-template>
                            <mat-card class="example-card">
                                <mat-card-header>
                                    <div mat-card-avatar class="example-header-image"></div>
                                    <mat-card-title>step 2</mat-card-title>
                                </mat-card-header>
                                <mat-card-content>
                                        <kt-steptwo></kt-steptwo>
                                </mat-card-content>
                            </mat-card>

                      </form>
                    </mat-step>

在我的register.ts下:

export class RegisterComponent implements OnInit, OnDestroy {
  isLinear = true;
}

现在 <kt-stepone>是我的第1步表单,是单独的模块,我在其中实现了“下一步”按钮。

现在,当我实现isLinear = true;时,即使填写了整个表格,它也不会继续进行下一步。如果我没有填写表格,则其工作按预期进行,用红色高亮

对于裁判,这是<kt-stepone>代码:

<form class="kt-form" [formGroup]="steponeForm" autocomplete="off" (ngSubmit)="onSubmit()">
            <div class="kt-portlet__body" >
                //MY FORM
            </div>
                 // submit button
            <button mat-button matStepperNext color="primary" type="submit">Next</button>

</form>

由于我是第一次使用angular,请告诉我这种方法在哪里出错了。

更新的KT-STEPONE.ts:

import { MatStepper } from '@angular/material/stepper';
completed=false;
@ViewChild('stepper') stepper: MatStepper;
onSubmit(){

    this.stepper.selected.completed = true;
    this.stepper.next();
  }




3 个答案:

答案 0 :(得分:0)

我认为您的步进器和kt-stepone无法沟通。尝试实现服务或@inpit @output来设置步骤有效。或者,如果逻辑分开,则可以删除[stepControl] 和 设置完成=“ false” 并在您的组件中

@ViewChild('stepper') stepper: MatStepper;
onButton() {
  this.stepper.selected.completed = true;
  this.stepper.next();
}

答案 1 :(得分:0)

对此进行RnD之后。我终于得到了可行的解决方案。请遵循此link。这样做的方法是:我们需要链接寄存器组件中的每个步骤组件。 Here是此指南。

答案 2 :(得分:0)

<mat-step [stepControl]="firstFormGroup">
    <form [formGroup]="firstFormGroup">
        <ng-template matStepLabel> step 1 </ng-template>
        <mat-card class="example-card">
            <mat-card-header>
                <div mat-card-avatar class="example-header-image"></div>
                <mat-card-title>step 1</mat-card-title>
            </mat-card-header>
            <mat-card-content>
                <kt-stepone></kt-stepone>
            </mat-card-content>

        </mat-card>

        <div>

        </div>
    </form>
</mat-step>
<mat-step [stepControl]="secondFormGroup">
    <form [formGroup]="secondFormGroup">
        <ng-template matStepLabel> step 2 </ng-template>
        <mat-card class="example-card">
            <mat-card-header>
                <div mat-card-avatar class="example-header-image"></div>
                <mat-card-title>step 2</mat-card-title>
            </mat-card-header>
            <mat-card-content>
                <kt-steptwo></kt-steptwo>
            </mat-card-content>
        </mat-card>

    </form>
</mat-step>