【发布时间】:2015-05-30 18:51:04
【问题描述】:
我正在使用这个 Bootstrap 日期时间选择器:http://eonasdan.github.io/bootstrap-datetimepicker/
我为 DateTime 创建了一个名为 datepicker 的自定义 Binder:
ko.bindingHandlers.datepicker = {
init: function(element, valueAccessor, allBindingsAccessor) {
//initialize datepicker with some optional options
var options = allBindingsAccessor().datepickerOptions || {format: 'DD/MM/YYYY HH:mm'};
$(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)) {
value(event.date);
}
});
},
update: function(element, valueAccessor) {
var widget = $(element).data("datepicker");
//when the view model is updated, update the widget
if (widget) {
widget.date = ko.utils.unwrapObservable(valueAccessor());
if (widget.date) {
widget.setValue();
}
}
}
};
我的模型是 JSON,当我将 C# dateTime 转换为 JSON 时,我得到这个日期:"/Date(1427368178393)/"
<div class="col-md-4">
<div class="form-group">
<label class="control-label">Quote Date</label>
<div class='input-group date dateTimes'>
<input type="text" class="form-control" data-bind="datepicker: QuoteDateTime" />
<span class="input-group-addon"><span class="glyphicon glyphicon-calendar"></span></span>
</div>
</div>
</div>
但问题是第一次加载页面时,即使 QuoteDateTime 的值没有显示在 DateTimePicker 中。
这里是 JSFiddle:
https://jsfiddle.net/mdawood1991/ezv7qxbt/
我需要在日期时间选择器中显示第一个值。
编辑
问题是我的 ViewModel 有一个住宿列表
这是我的 viewModel 的控制台日志
按照您的建议,我可以将每个 dateTime 转换为时刻,但我不应该使用淘汰赛映射插件:http://knockoutjs.com/documentation/plugins-mapping.html
这是循环通过我的视图模型然后将所有日期时间转换为时刻对象的唯一解决方案
【问题讨论】:
标签: datetime knockout.js knockout-mapping-plugin