Angular 7のDateTimeピッカーはありませんか?
Aug 30 2020
Angular 7のDateTimeピッカーが見つかりませんでした。そこで、DatePickerとTimePickerを組み合わせることにしました。
https://ng-bootstrap.github.io/#/components/datepicker
https://ng-bootstrap.github.io/#/components/timepicker
<ng-template #dateTimePicker>
<ngb-datepicker #createdStartDate name="datepicker"></ngb-datepicker>
<ngb-timepicker #createdStartTime name="timepicker" [meridian]="true"></ngb-timepicker>
</ng-template>
<form [formGroup]="managePromotionsForm"
<div class="col-md-6">
<div class="row form-group">
<label class="col-md-4 control-label" for="createdStartDate" translate="">Created From </label>
<div class="col-md-6">
<div class="input-group">
<input readOnly class="form-control" id="createdStartDate" placeholder="From Date"
[formControl]="controls['createdStartDate']">
<div class="input-group-append">
<button class="btn btn-outline-secondary calendar" [ngbPopover]="dateTimePicker" type="button"></button>
</div>
</div>
</div>
</div>
</div>
</form>
これは私が今まで持っているものです
選択した日付と時刻をcreatedStartDateテキストボックスに表示するにはどうすればよいですか?
回答
1 Eliseo Aug 30 2020 at 10:21
必要に応じて、ngbDropDown、ngbDatePicker、およびngbTimePickerと組み合わせて使用できます。
このためには、2つの変数と1つのゲッターが必要です
date: any;
time:any= {hour:0,minute:0};
_value;
label;
ngOnInit()
{
this.getDatetime()
}
getDatetime() {
let value = null;
if (!this.date) {
if (!this.time) value = "yyyy/MM/dd hh:mm";
else
value =
"yyyy/MM/dd " +
("0" + this.time.hour).slice(-2) +
":" +
("0" + this.time.minute).slice(-2);
}
if (!value) {
value = new Date(Date.UTC(
this.date.year,
this.date.month - 1,
this.date.day,
this.time ? this.time.hour : 0,
this.time ? this.time.minute : 0
);
this._value=value;
} else
this._value=null
this.form.get("control").setValue(this._value);
this.label=value;
}
<form [formGroup]="form">
<div ngbDropdown>
<button class="datepicker btn btn-link" ngbDropdownToggle>{{_value?(_value|date:'medium'):label}}</button>
<div ngbDropdownMenu >
<ngb-datepicker #dp [(ngModel)]="date" (dateSelect)="getDatetime()"[ngModelOptions]="{standalone:true}" ></ngb-datepicker>
<ngb-timepicker [ngModel]="time" (ngModelChange)="time=$event;getDatetime()"[ngModelOptions]="{standalone:true}"></ngb-timepicker>
</div>
</div>
<button class="btn btn-primary">submit</button>
stackblitzで見る
注:これは、依存関係を作らないようにカスタムフォームコントロールを作成する場合です。
好奇心のための更新、stackblitzでカスタムフォームコントロールを作成します
1 MuhammadKamran Aug 30 2020 at 08:15
バインドできるフォーム要素を作成する場合。より良い方法は、別のコンポーネントを作成し、制御値アクセサーを実装することです。
次に、コンポーネントをフォーム要素として使用し、ngModalまたはフォームコントロールをそれにバインドできます。