Ich benutze das Plugin bootstrap-datetimepicker mit knockout js. Ich habe einen Handler getan, um dynamisch zu verwalten und MaxDate MinDate, wie ich weiter unten zeigen:datetimepicker bootstrap minDate und maxDate im beobachtbaren Knockout
ko.bindingHandlers.dateTimePicker = {
init: function (element, valueAccessor, allBindingsAccessor) {
//initialize datepicker with some optional options
var options = allBindingsAccessor().dateTimePickerOptions || {};
$(element).datetimepicker(options);
//when a user changes the date, update the view model
ko.utils.registerEventHandler(element, "dp.change", function (event) {
var value = valueAccessor();
if (ko.isObservable(value)) {
if (event.date && event.date != null && !(event.date instanceof Date)) {
value(event.date.toDate());
} else {
//value(event.date);
value(undefined);
}
}
});
ko.utils.domNodeDisposal.addDisposeCallback(element, function() {
var picker = $(element).data("DateTimePicker");
if (picker) {
picker.destroy();
}
});
},
update: function (element, valueAccessor, allBindings, viewModel, bindingContext) {
var picker = $(element).data("DateTimePicker");
//when the view model is updated, update the widget
if (picker) {
//Usamos moment para convertir a fecha ya que utiliza este plugin adicional datetimepicker
var koDate = moment(ko.utils.unwrapObservable(valueAccessor()) || '');
if (koDate.isValid()) picker.date(koDate.toDate() || null);
}
}
};
ko.bindingHandlers.minDate = {
update: function (element, valueAccessor) {
var value = moment(ko.utils.unwrapObservable(valueAccessor()) || ''),
picker = $(element).data("DateTimePicker");
if (value.isValid() && picker) {
picker.minDate(value.toDate());
}
}
};
ko.bindingHandlers.maxDate = {
update: function (element, valueAccessor) {
var value = moment(ko.utils.unwrapObservable(valueAccessor()) || ''),
picker = $(element).data("DateTimePicker");
if (value.isValid() && picker) {
picker.maxDate(value.toDate());
}
}
};
ich es wie folgt verwenden:
<div class="input-group" data-bind="dateTimePicker: NuevaTarea.FechaInicio, dateTimePickerOptions: { format: 'L', showClear: true }, minDate: NuevaTarea.minDate, maxDate: NuevaTarea.maxDate">
<input type="text" class="form-control" />
<div class="input-group-addon">
<i class="fa fa-calendar"></i>
</div>
</div>
Das Problem ist, wenn eine Änderung der NuevaTarea.minDate und NuevaTarea. maxDate, das Datum von MaxDate wird NuevaTarea.FechaInicio zugewiesen.
Jemand könnte mir helfen, ein beobachtbares MaxDate MinDate zu erstellen und richtig zu funktionieren? Nein, ich mache falsch.
Die Version des Plugins ist 4.15.35. https://github.com/Eonasdan/bootstrap-datetimepicker
In der Plugin-Dokumentation heißt es, dass, wenn Sie die MinDate oder MaxDate ändern, automatisch das Ereignis dp.change erneut aufruft. Vielleicht ist da mein Fehler, aber nicht, wie ich diese Unannehmlichkeiten lösen soll. –