Ich verwende bootstrap-datepicker in meinem Angular-Projekt, indem Sie es als eine Richtlinie erstellen. Unten ist mein Code.Angular: Bind-Datum aus Bootstrap-Datepicker zu zugrunde liegenden ngModel oder FormControlName
HTML: <input [datepicker]="datepickerConfig" readonly ngModel name="requestedDate" class="form-control" id="requestedDate" type="text">
Datumsauswahl config in Komponente:
datepickerConfig = {
format: 'dd-M-yyyy'
};
Richtlinie:
@Directive({ selector: '[datepicker]' })
export class DatepickerDirective implements OnInit {
@Input() datepicker;
constructor(private el: ElementRef) { }
ngOnInit() {
$(this.el.nativeElement).datepicker(this.datepicker);
$(this.el.nativeElement).next('.input-group-addon').find('.glyphicon-calendar')
.click(() => $(this.el.nativeElement).focus());
}
}
Wenn ich auf das Textfeld konzentrieren, auf die ich diese Richtlinie angewendet haben, die Datepicker erscheint, und wenn ich ein Datum auswähle, wird es in der Textbox angezeigt. Aber es wird nicht an den zugrunde liegenden ngModel
/formControlName
gebunden. Die entsprechende Variable ist immer noch undefined
.
Bitte helfen Sie mir dabei.