可以手动在失焦时触发验证,从而实现在未选择结束日期时触发失焦事件的效果。
代码示例:
HTML:
在组件中添加以下代码:
import { Component } from '@angular/core'; import { FormGroup, FormBuilder, Validators } from '@angular/forms';
@Component({ selector: 'app-date-range-input-example', templateUrl: 'date-range-input-example.html' }) export class DateRangeInputExample { range: FormGroup;
constructor(fb: FormBuilder) { this.range = fb.group({ start: [null, Validators.required], end: [null, Validators.required] }); }
onRangeInputBlur() { if (!this.range.value.end) { this.range.controls.end.markAsTouched(); } } }
在这个例子中,我们在 mat-date-range-input 上添加了一个 rangeInputBlurred 事件,该事件会在失焦时触发。在 onRangeInputBlur() 函数中,我们手动检查了结束日期是否存在,如果不存在则触发验证,从而达到触发失焦事件的效果。