以下のコードを使用してDatePickerの値を設定しようとしていますが、「Change」イベントが発生することを期待していますが、発生しません。
var datePicker = $("#datePicker").data("kendoDatePicker");
var previousDate = new Date(datePicker.value());
previousDate.setDate(previousDate.getDate() - 1);
$("#displayDate").text(kendo.toString(new Date(previousDate), 'D'));
datePicker.value(previousDate);
ただし、ユーザーインターフェイスを使用して日付値を変更すると、期待どおりに「変更」イベントが発生します。
以下のコードスニペットを試してください。
HTML
<input id="datepicker" />
<input type="button" value="set date" onclick="setdateInDP()">
JS
<script type="text/javascript">
$(document).ready(function () {
function onChange() {
alert("Change :: " + kendo.toString(this.value(), 'd'));
}
$("#datepicker").kendoDatePicker({
change: onChange
});
});
function setdateInDP() {
var datePicker = $("#datepicker").data("kendoDatePicker");
var previousDate = new Date(datePicker.value());
previousDate.setDate(previousDate.getDate() - 1);
datePicker.value(previousDate);
$("#datepicker").data("kendoDatePicker").trigger("change");
}