如何在kendo mvc in-cell批量编辑网格中创建bootstrap 3 datepicker

时间:2014-03-20 06:04:26

标签: kendo-ui kendo-grid kendo-asp.net-mvc kendo-ui-mvc

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

MODEL

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; }

GRID

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();
}

EDITOR TEMPLATE

@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>

2 个答案:

答案 0 :(得分:0)

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

1)在网格列/模型中,使用您的ActualStartDate属性。然后,您可以使用列上的.Format()方法对其进行格式化。

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

答案 1 :(得分:0)

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