эй, я хочу добавить тире, когда пользователь вводит дату рождения вручную.
как это
08-18-2019
но я не могу этого сделать
public dateOfBirth: { year: number; month: number; day: number };
HTML-файл
<input
ngbDatepicker
dobMask
#d="ngbDatepicker"
#dobF="ngModel"
class="form-control input-underline input-lg"
id="dob"
[(ngModel)]="dateOfBirth"
placeholder="mm-dd-yyyy"
name="dp"
[ngClass]="{
invalid:
(dobF.value === null || isString(dobF.value) || futureDate) && dobF.touched
}"
required
/>
я попробовал директиву, но результат примерно такой
11 --------- 3
вот мой код директивы
@Directive({
selector: '[dobMask]'
})
export class DobDirective {
@HostListener('input', ['$event'])
onKeyDown(event: KeyboardEvent) {
const input = event.target as HTMLInputElement;
let trimmed = input.value.replace(/\s+/g, '');
if (trimmed.length > 8) {
trimmed = trimmed.substr(0, 8);
}
let numbers = [];
for (let i = 0; i < trimmed.length; i += 2) {
numbers.push(trimmed.substr(i, 2));
}
input.value = numbers.join('-');
}
}
это то, что я получаю
![enter image description here](https://i.stack.imgur.com/Ksw9N.png)
мой ожидаемый результат
т.е. 08-17-2019
Кто-нибудь может мне помочь, как мне этого добиться?