将管道或转换应用到响应式表单值
Applying a pipe or transform to a Reactive Form value
我正在构建一个简单的响应式表单。为简单起见,假设我要显示的唯一数据是日期。
test.component.html
<form novalidate [formGroup]="myForm">
<input type="date" formControlName="date">
</form>
test.component.ts
private date: Date = Date.now();
ngOnInit() {
this.myForm = this.fb.group({
date: [this.date, [Validators.required]]
});
}
模板上的输入类型=日期字段要求日期格式为'yyyy-MM-dd'。事件中的值是一个 JavaScript 日期对象。
如何在模板级别修改数据以使输入值正确?
我试过的:
一种方法是将 DatePipe 注入我的组件并在代码中应用转换。
date: [datePipe.transform(this.event.date, 'yyyy-MM-dd'), [Validators.required]]
但这将模板的实现细节与组件联系在一起。例如,如果 NativeScript 模板要求日期采用 MM/dd/yyyy
格式怎么办? formGroup 不再有效。
在@n00dl3 的帮助下,我想出的唯一方法是包装 md-input 组件并通过 ControlValueAccessor
提供正确的值
import { Component, Input, ViewChild } from '@angular/core';
import { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';
import { DatePipe } from '@angular/common';
import { MdInput } from '@angular/material';
@Component({
selector: 'md-date-input',
template: `
<md-input [placeholder]="placeholder"
type="date"
(change)="update()"
[value]="dateInput">
</md-input>`,
providers: [
{ provide: NG_VALUE_ACCESSOR, useExisting: DateInputComponent, multi: true }]
})
export class DateInputComponent implements ControlValueAccessor {
@Input() placeholder: string;
@ViewChild(MdInput) mdInput: MdInput;
dateInput: string;
onChange: (value: any) => void;
constructor(private datePipe: DatePipe) {
}
writeValue(value: any) {
this.dateInput = value == null ? '' : this.datePipe.transform(value, 'yyyy-MM-dd');
}
registerOnChange(fn: (value: any) => void) {
this.onChange = fn;
}
registerOnTouched(fn: (value: any) => void) {
}
update() {
this.onChange(this.mdInput.value ? new Date(this.mdInput.value) : '');
}
}
我正在构建一个简单的响应式表单。为简单起见,假设我要显示的唯一数据是日期。
test.component.html
<form novalidate [formGroup]="myForm">
<input type="date" formControlName="date">
</form>
test.component.ts
private date: Date = Date.now();
ngOnInit() {
this.myForm = this.fb.group({
date: [this.date, [Validators.required]]
});
}
模板上的输入类型=日期字段要求日期格式为'yyyy-MM-dd'。事件中的值是一个 JavaScript 日期对象。
如何在模板级别修改数据以使输入值正确?
我试过的:
一种方法是将 DatePipe 注入我的组件并在代码中应用转换。
date: [datePipe.transform(this.event.date, 'yyyy-MM-dd'), [Validators.required]]
但这将模板的实现细节与组件联系在一起。例如,如果 NativeScript 模板要求日期采用 MM/dd/yyyy
格式怎么办? formGroup 不再有效。
在@n00dl3 的帮助下,我想出的唯一方法是包装 md-input 组件并通过 ControlValueAccessor
import { Component, Input, ViewChild } from '@angular/core';
import { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';
import { DatePipe } from '@angular/common';
import { MdInput } from '@angular/material';
@Component({
selector: 'md-date-input',
template: `
<md-input [placeholder]="placeholder"
type="date"
(change)="update()"
[value]="dateInput">
</md-input>`,
providers: [
{ provide: NG_VALUE_ACCESSOR, useExisting: DateInputComponent, multi: true }]
})
export class DateInputComponent implements ControlValueAccessor {
@Input() placeholder: string;
@ViewChild(MdInput) mdInput: MdInput;
dateInput: string;
onChange: (value: any) => void;
constructor(private datePipe: DatePipe) {
}
writeValue(value: any) {
this.dateInput = value == null ? '' : this.datePipe.transform(value, 'yyyy-MM-dd');
}
registerOnChange(fn: (value: any) => void) {
this.onChange = fn;
}
registerOnTouched(fn: (value: any) => void) {
}
update() {
this.onChange(this.mdInput.value ? new Date(this.mdInput.value) : '');
}
}