剑道控制日期选择器并不了解MVVM中的日期格式

时间:2014-04-08 18:02:26

标签: kendo-ui kendo-datetimepicker

我有以下代码:

 <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拿起这个日期?

3 个答案:

答案 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",
});