我有以下代码:
<input data-role="datepicker" data-bind="value:referralData.Referral.from_date" />
使用要绑定的值:
from_date: "2014-01-01T00:00:00"
在对象中它不再绑定。 我试过了:
<input data-role="datepicker" data-bind="value:referralData.Referral.from_date, parseFormats:'YYYY-MM-DD\Thh:mm:ss'" />
但是它声明:Uncaught Error:DatePicker小部件不支持parseFormats绑定。所以我相信我有一个我遗漏的语法错误。
有谁知道怎么告诉datepicker拿起这个日期?
答案 0 :(得分:2)
data-bind
适用于实时绑定选项。如果您只想使用配置选项,则可以使用data-parse-formats
:
<input data-role="datepicker"
data-parse-formats="YYYY-MM-DDThh:mm:ss"
data-bind="value:referralData.Referral.from_date" />
此外,如果您想使用24小时制,您应该使用此格式配置时间:HH:mm:ss
答案 1 :(得分:1)
@Lars的解决方案有效,但日期格式说明符错误(截至Kendo版本2014.3.119)。应为yyyy-MM-ddTHH:mm:ss
(年份和日期为小写,小时为大写):
<input
data-role="datepicker"
data-bind="value:referralData.Referral.from_date"
data-parse-formats="yyyy-MM-ddTHH:mm:ss" />
作为完成,如果有时你需要,你实际上可以根据documentation传递多种格式,如下所示:
<input
data-role="datepicker"
data-bind="value:referralData.Referral.from_date"
data-parse-formats="['yyyy-MM-ddTHH:mm:ss','yyyy-MM-dd']" />
答案 2 :(得分:0)
您可以为日期格式创建自定义绑定:
自定义绑定
kendo.data.binders.widget.dateFormat = kendo.data.Binder.extend({
init: function (widget, bindings, options) {
//call the base constructor
kendo.data.Binder.fn.init.call(this, widget.element[0], bindings, options);
},
refresh: function () {
var that = this,
value = that.bindings["dateFormat"].get(); //get the value from the View-Model
$(that.element).data("kendoDatePicker").setOptions({
format: value
}); //update the widget
}
});
HTML
<div id="report1" data-role="view" data-model="APP.models.report1">
<input data-role="datepicker" data-bind="value: start_date, dateFormat: date_format" />
</div>
模型
window.APP = {
models: {
report1: kendo.observable({
start_date: new Date(),
date_format: "dd/MM/yyyy",
}),
}
};
var app = new kendo.mobile.Application($(document.body), {
initial: "report1",
skin: "default",
});