0

我正在尝试让 dgrid OnDemandGrid 与 dijit.form.DateTextBox 作为编辑器一起使用。数据通过 JSON 馈送到 OnDemandGrid。最初,我试图从 MySQL 数据库(例如YYYY-MM-DD HH:MM:SS)提供原始格式的日期,但是当 DateTextBox 似乎无法解析该字符串时,我尝试只提供日期(例如2012-11-20)。然而,这也没有奏效。

所以,我的主要问题是让 DateTextBox 处理日期信息。第二个问题是如何处理时间信息,因为 DateTextBox 不能编辑时间。我目前的方法是,当我拆分 SQL 日期字符串时,我将时间作为 dijit.form.TimeTextBox 的单独列提供给 dgrid。这似乎是一个混乱的解决方案,所以我愿意接受建议。

这是我的网格代码:

var grid = new declare([OnDemandGrid, Editor, Keyboard, Selection])({
    store: store,
    query: {aid: "1900", action: "objectListGenerator2" },
    bufferRows: 40,
    loadingMessage: "Loading...",
    columns: [
        {field: "oid", label: "Object ID"},
        Editor({field: "startDate", name: "Start Date", editorArgs: { selector: 'date', datePattern: 'yyyy-mm-dd', locale: 'en-us' }}, DateTextBox, "click"),
        Editor({field: "startTime", name: "Start Time"}, TimeTextBox, "click"),
        Editor({field: "endDate", name: "End Date"}, DateTextBox, "click"),
        Editor({field: "endTime", name: "End Time"}, TimeTextBox, "click"),
        {field: "endDateOid", label: "End OID"}
    ],
}, "grid");

这是我的 JSON 源的示例字符串:

[{"content":"2012-11-20 18:12:00","oid":"2112","author":"","endDateOid":"2113","group":"","endTime":"17:59:00","poid":"0","id":null,"startTime":"18:12:00","gmt":"2012-11-22 00:12:43","name":"The Windows 8 Disaster Rolls On","paid":"1900","endDate":"2012-11-21","type":"startDate","startDate":"2012-11-20","cache":"","cachedate":"0000-00-00 00:00:00"},
{"content":"2013-01-01 17:59:00","oid":"2114","author":"","endDateOid":"2115","group":"","endTime":"16:59:00","poid":"0","id":1,"startTime":"17:59:00","gmt":"2012-11-22 00:14:49","name":"The Windows 8 Disaster Rolls On","paid":"1900","endDate":"2013-01-02","type":"startDate","startDate":"2013-01-01","cache":"","cachedate":"0000-00-00 00:00:00"}]
4

1 回答 1

0

正如我在评论中指出的那样,如果我从列定义中删除“单击”,从而允许立即创建 DateTextBox,则会显示正确的日期。如果稍后添加 DateTextBox,我不确定为什么无法正确解析数据,但至少立即创建它会产生可行的结果。

于 2013-01-03T04:05:26.423 回答