【发布时间】:2018-03-12 22:43:42
【问题描述】:
我有一个像这样的反应形式的组件......
表单组件.html
<form [formGroup]="form" class="do-form">
<div formGroupName="dot">
<div class="do-form__container">
<div class="do-form__group">
<label for="day">Day</label>
<input id="day" type="number" placeholder="XX" class="do-form__group__control" formControlName="day" />
</div>
<div class="do-form__group">
<label for="month">Month</label>
<input id="month" type="number" placeholder="XX" class="do-form__group__control" formControlName="month" />
</div>
<div class="do-form__group">
<label for="year">Year</label>
<input id="year" type="number" placeholder="XXXX" class="do-form__group__control" formControlName="year" />
</div>
</div>
<div class="do-form__errors" *ngIf="isValid()">
<p>Please enter a valid date</p>
</div>
</div>
</form>
在我的 form.component.ts
form = this.fb.group({
dot: this.fb.group({
day: ['',
[
Validators.required,
Validators.min(1),
Validators.max(31)
]],
month: ['',
[
Validators.required,
Validators.min(1),
Validators.max(12)
]],
year: ['2018',
[
Validators.required,
Validators.min(1918),
Validators.max(2018)
]]
})
});
isValid() {
return (
!this.form.valid &&
this.form.get('dot.day').touched &&
this.form.get('dot.month').touched &&
this.form.get('dot.year').touched
);
}
现在我有一个单独的页面(app.component.html)像这样
<app-form #formTool></app-form>
<button class="full-width-btn" (click)="next(); form.sendResult();">SEND</button>
app.component.ts
import { formComponent } from '../form-component/form-component.ts'
export ...
@ViewChild(formComponent) form;
现在基本上我想禁用发送按钮,直到应用程序表单组件中的表单有效。
我不完全确定如何执行此操作。我曾考虑在共享服务器上存储valid 事件,但我不确定如何在服务中存储valid 事件。我看到,对于非响应式表单,您可以只使用一个使用相同 ngModel 的按钮,但再次不确定这是否适用于这种情况。
任何帮助将不胜感激!
编辑
我试过[disabled]="form.invalid" 和[disabled]="!isValid()" 但我仍然可以点击按钮
我也尝试过使用[disabled]=!form.isValid() 和[disabled]=!form.form.isValid()
谢谢
【问题讨论】:
标签: javascript angular typescript angular5