-1

需要在此输入中将波斯数字转换为英文数字<input type="text" formControlName="mobile" myCustomDirective />。所以创建了一个指令,输入波斯数字事件以该值触发,然后我将其更改为英文数字,​​所有事件再次以英文数字触发。如果我阻止事件触发第二次更改,那是错误的,因为我需要使用英文数字触发事件。实际上,我需要在FormControl指令捕获它之前获取输入的值并将其更改为英语。有什么解决办法吗?

4

1 回答 1

1

最后我可以解决我的问题:

import { DecimalPipe } from '@angular/common';
import { Directive, ElementRef, forwardRef, HostListener } from '@angular/core';
import { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';
@Directive({
selector: '[appInputConvertNumbers]',
providers: [
 {
  provide: NG_VALUE_ACCESSOR,
  useExisting: forwardRef(() => InputConvertNumbersDirective),
  multi: true
 },
  DecimalPipe
]
})
export class InputConvertNumbersDirectiveimplements ControlValueAccessor {
private _onChange: (value: any) => {};
  constructor(private _elementRef: ElementRef) { }
  @HostListener('input') onInput() {
    let value = this._elementRef.nativeElement.value;
    let newValue = this.setInputValue(value);
    this._onChange(newValue);
  }
  private setInputValue(value: string): string {
    value = value.replace(/[۰-۹]/g, number => '۰۱۲۳۴۵۶۷۸۹'.indexOf(number).toString())
    this._elementRef.nativeElement.value = value;
    return value;
  }
  writeValue(value: string): void {
    this.setInputValue(value);
  }
  registerOnChange(fn: any): void {
    this._onChange = fn;
  }
  registerOnTouched(fn: any): void {
  }
}

并且简单地以我可以使用此指令的形式

<form [formGroup]="exampleForm">
  <input appInputConvertNumbers formControlName="number">
</form>
于 2020-12-23T19:31:13.120 回答