当任何可观察对象被更新时,我在更新对象订阅时遇到了一些麻烦。
这是我正在使用的模型:
searchModel = function (startDate, endDate, searchTerm) {
var self = this;
self.StartDate = ko.observable(startDate);
self.EndDate = ko.observable(endDate);
self.SearchTerm = ko.observable(searchTerm);
};
这是我用来更新日期选择器的可观察对象的绑定处理程序:
ko.bindingHandlers.datepicker = {
init: function (element, valueAccessor, allBindingsAccessor) {
//initialize datepicker with some optional options
var options = allBindingsAccessor().datepickerOptions || {};
$(element).datepicker(options).on("changeDate", function (ev) {
var observable = valueAccessor();
observable(ev.date);
});
},
update: function (element, valueAccessor) {
var value = ko.utils.unwrapObservable(valueAccessor());
$(element).datepicker("setValue", value);
}
};
这是我用来初始化和订阅搜索模型的扩展器函数:
ko.extenders.getEvents = (function (target, options) {
function getEvents(target) {
console.log(target);
};
getEvents(target());
target.subscribe(getEvents);
return target;
});
任何帮助将不胜感激...简而言之,我希望页面使用默认的可观察模型值(如下)进行初始化,并且每当对象中的任何可观察对象被更新时,订阅就会触发,以便我可以“做事”。
this.SearchCriteria = ko.observable(new searchModel('', '', '')).extend({
getEvents: null
});
这是我正在使用的:JSFiddle