本文介绍了如何在Mat-Stepper中传递模板的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我想这样做:
<ng-template #content>
<mat-step>step 1</mat-step>
<mat-step>step 2</mat-step>
</ng-template>
<mat-horizontal-stepper>
<ng-container *ngTemplateOutlet="content"></ng-container>
</mat-horizontal-stepper>
但是我得到这个错误
我认为这是因为mat-step在其构造函数中注入了mat-stepper https://github.com/angular/material2/blob/master/src/lib/stepper/stepper.ts#L53
I think this is because mat-step inject a mat-stepper in it's constructorhttps://github.com/angular/material2/blob/master/src/lib/stepper/stepper.ts#L53
所以我尝试在ngOutletContext的上下文中传递stepper
So I tryed to pass stepper
in the context with ngOutletContext
<mat-horizontal-stepper #ContainerStepper="matHorizontalStepper">
<ng-container *ngTemplateOutlet="content" ngOutletContext="{$implicit:{stepper:ContainerStepper}}"></ng-container>
</mat-horizontal-stepper>
但这是行不通的.
有什么主意吗?
推荐答案
您可以尝试:
<ng-template #step1Template>
<form>
<mat-form-field>
<input matInput placeholder="Last name, First name" required>
</mat-form-field>
</form>
</ng-template>
<ng-template #step2Template>
<form>
<mat-form-field>
<input matInput placeholder="Address" required>
</mat-form-field>
</form>
</ng-template>
<mat-horizontal-stepper>
<mat-step [stepControl]="firstFormGroup">
<!-- stepper title !-->
<ng-template matStepLabel>Fill out your name</ng-template>
<!-- end stepper title !-->
<!-- stepper content !-->
<ng-container *ngTemplateOutlet="step1Template"></ng-container>
<!-- end stepper content !-->
<!-- stepper footer !-->
<div>
<button mat-button matStepperNext>Next</button>
</div>
<!-- end stepper footer !-->
</mat-step>
<mat-step [stepControl]="secondFormGroup">
<!-- stepper title !-->
<ng-template matStepLabel>Fill out your address</ng-template>
<!-- end stepper title !-->
<!-- stepper content !-->
<ng-container *ngTemplateOutlet="step2Template"></ng-container>
<!-- end stepper content !-->
<!-- stepper footer !-->
<div>
<button mat-button matStepperPrevious>Back</button>
<button mat-button matStepperNext>Next</button>
</div>
<!-- end stepper footer !-->
</mat-step>
<mat-step>
<ng-template matStepLabel>Done</ng-template>
You are now done.
<div>
<button mat-button matStepperPrevious>Back</button>
<button mat-button (click)="stepper.reset()">Reset</button>
</div>
</mat-step>
</mat-horizontal-stepper>
<mat-vertical-stepper>
<mat-step [stepControl]="firstFormGroup">
<!-- stepper title !-->
<ng-template matStepLabel>Fill out your name</ng-template>
<!-- end stepper title !-->
<!-- stepper content !-->
<ng-container *ngTemplateOutlet="step1Template"></ng-container>
<!-- end stepper content !-->
<!-- stepper footer !-->
<div>
<button mat-button matStepperNext>Next</button>
</div>
<!-- end stepper footer !-->
</mat-step>
<mat-step [stepControl]="secondFormGroup">
<!-- stepper title !-->
<ng-template matStepLabel>Fill out your address</ng-template>
<!-- end stepper title !-->
<!-- stepper content !-->
<ng-container *ngTemplateOutlet="step2Template"></ng-container>
<!-- end stepper content !-->
<!-- stepper footer !-->
<div>
<button mat-button matStepperPrevious>Back</button>
<button mat-button matStepperNext>Next</button>
</div>
<!-- end stepper footer !-->
</mat-step>
<mat-step>
<ng-template matStepLabel>Done</ng-template>
You are now done.
<div>
<button mat-button matStepperPrevious>Back</button>
<button mat-button (click)="stepper.reset()">Reset</button>
</div>
</mat-step>
</mat-vertical-stepper>
这篇关于如何在Mat-Stepper中传递模板的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!