0

所以我可以在较新的浏览器中使这项工作正常,但在 IE9 中,当在日期选择器上单击日期时,单元格将返回为未选中、空且不脏。我的代码的一个例子是

模型

public string name { get; set; }

[DataType(DataType.Date)]
[DisplayFormat(ApplyFormatInEditMode = true, DataFormatString = "{0:d}", NullDisplayText = "")]
[Display(Name = "Actual Start")]
public DateTime? ActualStartDate { get; set; }

public DateTime? ActualEndDate { get; set; }

网格

Html.Kendo().Grid<MilestoneDto>()

     .Name("editMilestoneList")
     .Columns(columns =>
     {
         columns.Bound(m => m.Name).Title("Name");
         columns.Bound(m => m.Status).EditorTemplateName("_milestoneStatus");
         columns.Bound(m => m.PlannedStartDateStringValue);
         columns.Bound(m => m.ProjectedStartDateStringValue);
         columns.Bound(m => m.ActualStartDate).EditorTemplateName("GenericDatePicker");
         columns.Bound(m => m.PlannedEndDateStringValue);
         columns.Bound(m => m.ProjectedEndDateStringValue);
         columns.Bound(m => m.ActualEndDateStringValue).EditorTemplateName("GenericDatePicker");
         columns.Bound(m => m.CommentCount).ClientTemplate("<a href='javascript:;' onclick='callCommentModal()'>#if(CommentCount > 0) {# <span class=\"badge\">#=CommentCount#</span>#}else{#<span class=\"fa fa-plus-circle\"></span>#}#</a>").Title("Comments").Sortable(false).IncludeInMenu(false);
     })
     .HtmlAttributes(new { @class = "hidden results table-responsive" })
     .DataSource(dataSource => dataSource
                                 .Ajax()
                                 .Read(read => read.Action("DataSource", "Milestone").Data("additionalParams"))
                                 .Update(update => update.Action("BatchEdit", "Milestone"))
                                 .Batch(true)
                                 .Events(e => e.Sync("SyncGrid"))
                                 .ServerOperation(false)
                                 .Model(m => {
                                     m.Id(mf => mf.Id);
                                     m.Field(f => f.Name).Editable(false);
                                     m.Field(f => f.Status).Editable(ViewBag.IsBaselined);
                                     m.Field(f => f.PlannedStartDateStringValue).Editable(false);
                                     m.Field(f => f.PlannedEndDateStringValue).Editable(false);
                                     m.Field(f => f.CommentCount).Editable(false);
                                     m.Field(f => f.ProjectedStartDateStringValue).Editable(false);
                                     m.Field(f => f.ProjectedEndDateStringValue).Editable(false);
                                     m.Field(f => f.ActualStartDate).Editable(ViewBag.IsBaselined);
                                     m.Field(f => f.ActualEndDate).Editable(ViewBag.IsBaselined);                          
                                 })
     )
     .Editable(editable => editable.Mode(GridEditMode.InCell))
     .ColumnMenu()
     .Filterable()
     .Sortable();
}

编辑器模板

@model DateTime? 
@Html.TextBoxFor(model => model, new { @class="k-textbox bootStrapDatePicker form-   control" })
<script type="text/javascript">
    $('.bootStrapDatePicker').datepicker({ startDate: '0', format: "m/d/yyyy", autoclose:   true });
</script>
4

2 回答 2

0

您有两个(更好的)选项可以自动为您设置 DateTimePicker:

1)在网格列/模型中,使用您的ActualStartDate属性。然后,您可以使用.Format()列上的方法来设置您想要的格式。

2)我不知道确切的语法是什么,但是当您Model在网格中定义时,我相信有一种DataType()或类似的方法可以将其设置为日期时间。

于 2014-03-20T13:49:32.283 回答
0

已经有一段时间了,但事实证明问题是 jquery 的版本不正确。

于 2014-04-17T18:36:25.463 回答