【发布时间】:2012-03-22 02:08:22
【问题描述】:
我在将日期绑定到我的视图模型上的对象时遇到问题。我有一个从服务器获取的日期。
var viewModel = {
profile : ko.mapping.fromJS(initialData),
我将属性绑定到一个文本框。
<input data-bind="datepicker: profile.Birthdate()" />
我正在使用我在这里找到的自定义绑定:http://jsfiddle.net/rniemeyer/NAgNV/
ko.bindingHandlers.datepicker = {
init: function(element, valueAccessor, allBindingsAccessor) {
//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();
ko.observable($(element).datepicker("getDate"));
$(element).blur();
});
//handle disposal (if KO removes by the template binding)
ko.utils.domNodeDisposal.addDisposeCallback(element, function() {
$(element).datepicker("destroy");
});
},
update: function(element, valueAccessor) {
var value = ko.utils.unwrapObservable(valueAccessor()),
current = $(element).datepicker("getDate");
if(value != null)
{
if(value.toString()[0] = "/")
value = new Date(parseInt(value.toString().substr(6)));
}
if (value - current !== 0) {
$(element).datepicker("setDate", value);
}
}
};
我添加了 if(value.toString()[0] = "/") 用于格式化显示在文本框中的日期。
这似乎工作得很好,除非我尝试保存对象添加将它发送回服务器。我添加了一个警报来验证,在我将对象发送到服务器之前,日期没有变化。
save : function(){
alert(this.profile.Birthdate);
关于我做错了什么有什么想法吗?
感谢您的宝贵时间。
【问题讨论】:
标签: asp.net asp.net-mvc-3 jquery-ui knockout.js jquery-ui-datepicker