我尝试在输入字段格式/掩码值时键入,而实际模型保留原始(或不同格式)值。我正在考虑电话号码等,但为了简单起见,我使用大写字母进行测试。Angular 2 - 输入掩码:输入框显示格式化值,而模型保留未格式化的值
我试过一堆东西,希望它像指令一样简单。但似乎无法使显示值偏离表单值。
普拉克:http://plnkr.co/edit/VH5zn4S8q28CBpFutBlx?p=preview
这里的指令:
@Directive({
selector: '[uppercase]',
host: {
'(input)': 'onInputChange()',
}
})
export class UppercaseDirective {
constructor(private model: NgFormControl) { }
onInputChange() {
let newValue = this.model.value.toUpperCase();
this.model.viewToModelUpdate(newValue);
this.model.valueAccessor.writeValue(newValue);
}
}
和形式:
<form [ngFormModel]='myForm'>
<input [ngFormControl]='myForm.controls.field' uppercase>
<div>
{{ myForm.value.field }}
</div>
</form>
为什么不能管?听起来像你只是想要一种不同的方式来显示文字。 –
我想要在输入框中输入格式 - 输入掩码。我只在测试中显示视图中的值。 – Steve