所以我正在使用这个日期选择器库。 http://eonasdan.github.io/bootstrap-datetimepicker/Installing/#knockout
有没有办法让我从处理程序中获取值并将其保存在我的 View 模型中?我想在 View 模型内的处理程序之外公开 var picker = $(element).data('DateTimePicker'); 的值。这可能吗?
/*globals Hilary*/
Hilary.scope('learn').register({
name: 'DatetimeVM',
dependencies: ['ko', 'jQuery', 'moment', 'OptionSelectVM'],
factory: function (ko, $, moment, OptionSelectVM) {
'use strict';
return function (date) {
var self = {
date: {
type: ko.observable(),
start: ko.observable(),
end: ko.observable()
}
};
if(!ko.bindingHandlers.dateTimePicker) {
ko.bindingHandlers.dateTimePicker = {
init: function (element, valueAccessor, allBindingsAccessor) {
//initialize datepicker with some optional options
var viewOptions = allBindingsAccessor().dateTimePickerOptions || {},
options;
options = $.extend({
inline: true,
debug: true
}, viewOptions);
$(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 !== null && !(event.date instanceof Date)) {
value(event.date.toDate());
} else {
value(event.date);
}
}
});
ko.utils.domNodeDisposal.addDisposeCallback(element, function () {
var picker = $(element).data('DateTimePicker');
if (picker) {
picker.destroy();
}
});
},
update: function (element, valueAccessor) {
var picker = $(element).data('DateTimePicker');
//when the view model is updated, update the widget
if (picker) {
var koDate = ko.utils.unwrapObservable(valueAccessor());
//in case return from server datetime i am get in this form for example /Date(93989393)/ then fomat this
// koDate = (typeof (koDate) !== 'object') ? new Date(parseFloat(koDate.replace(/[^0-9]/g, ''))) : koDate
picker.date(koDate);
}
}
};
}
return self;
};
}
});
最佳答案
是的,你可以!查看the custom bindings documentation ,传递给绑定(bind)处理程序的 init
和 update
函数的参数比您当前使用的要多,其中包括用于预 knockout 的第四个名为 viewModel
的参数3.x 和 3.x 版本的 bindingContext
。
来自提到的文档:
viewModel
— This parameter is deprecated in Knockout 3.x. UsebindingContext.$data
orbindingContext.$rawData
to access the view model instead.bindingContext
— An object that holds the binding context available to this element’s bindings. This object includes special properties including$parent
,$parents
, and$root
that can be used to access data that is bound against ancestors of this context.
但请注意,这会创建从处理程序到特定 View 模型的依赖关系,恕我直言,这通常是一个危险信号。在绑定(bind)处理程序应该知道的当前 View 模型上显式传递可观察或回调可能会更好,因此您可以编写例如:
<div data-bind="datepicker: { date: myDate, additionalData: someObservable }"></div>
关于javascript - 如何访问自定义 knockout 绑定(bind)内的变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32386651/