我有一個自定義knockoutJs綁定的日期選擇器。Knockout DatePicker綁定項不禁用DatePicker
ko.bindingHandlers.valueAsDatePicker = {...}
當綁定輸入字段的狀態(使能/禁止)被綁定到一個可觀察到的KO它不啓用/禁用日期選擇器圖標。
HTML
<input id="txtRequestedTo" type="text" placeholder="dd/mm/yyyy"
data-bind="valueAsDatePicker: reqDateTo, disable: reqDateFrom().length < 1" />
自定義綁定
ko.bindingHandlers.valueAsDatePicker = {
init: function(element, valueAccessor, allBindingsAccessor) {
ko.bindingHandlers.value.init(element, valueAccessor, allBindingsAccessor);
formatAndSetDateValue(element, valueAccessor, allBindingsAccessor);
// Init UI datepicker
var dateFormat = allBindingsAccessor.dateFormat
$(element).datepicker({
dateFormat: dateFormat,
changeMonth: true,
changeYear: true,
yearRange: '1900:' + new Date().getFullYear(),
maxDate: 0,
showOn: "button",
buttonImage: "Content/images/sprite-base/sprite/icon-calender.png",
buttonImageOnly: true,
constrainInput: false,
buttonText: ""
});
},
update: function(element, valueAccessor, allBindingsAccessor) {
// Use the value binding
ko.bindingHandlers.value.update(element, valueAccessor, allBindingsAccessor);
formatAndSetDateValue(element, valueAccessor, allBindingsAccessor);
valueAccessor().valueHasMutated();
}
};
我想如果元素被禁用,反之亦然要禁用的日期選擇器。
感謝羅伯特我今天會嘗試這個,並會告訴你我是否有任何問題。 – Kiwironic
禁用可觀察的替換完美,我喜歡它是多麼的整潔。綁定部分有一些錯別字,但它仍然不起作用。我目前正在調試它。 – Kiwironic