モデル プロパティが ko.observable() の場合、これらはカスタム バインディング内で以下のようにアクセスできます。
var observable = valueAccessor();
Knockout-ES5 プラグインを使用する場合、カスタム バインディング内でオブザーバブルを取得するにはどうすればよいですか? 以下のコードを確認して、「ここで propertyName を取得するにはどうすればよいですか?」というコメントを探します。
Knockout-ES プラグインを使用しない場合の JS Fiddle提供: Another Look at Custom Bindings for KnockoutJS
Knockout-ES プラグインを使用するようにモデルを変更して更新されたフィドル
ko.bindingHandlers.datepicker = {
init: function(element, valueAccessor, allBindingsAccessor, viewModel) {
//initialize datepicker with some optional options
var options = allBindingsAccessor().datepickerOptions || {};
$(element).datepicker(options);
//handle the field changing
ko.utils.registerEventHandler(element, "change", function () {
var observable = valueAccessor();
if (!ko.isObservable(observable)) {
console.log("Not Observable");
//How to get propertyName here?
//ko.getObservable(viewModel, 'propertyName');
return;
}
observable($(element).datepicker("getDate"));
});
//handle disposal (if KO removes by the template binding)
ko.utils.domNodeDisposal.addDisposeCallback(element, function() {
$(element).datepicker("destroy");
});
},
//update the control when the view model changes
update: function(element, valueAccessor) {
var value = ko.utils.unwrapObservable(valueAccessor()),
current = $(element).datepicker("getDate");
if (value - current !== 0) {
$(element).datepicker("setDate", value);
}
}
};
var viewModel = {
myDate: new Date("11/01/2011"),
setToCurrentDate: function() {
this.myDate = new Date();
}
};
ko.track(viewModel);
ko.applyBindings(viewModel);