我在网格编辑(GridEditMode.InCell)中使用ASP.NET MVC 4和Telerik的KendoUI网格控件。我能够在网格中看到数据并编辑数据,但问题是,当我单击单元格进行编辑时,我没有获得Kendo UI控件(DatePicker,...)。我正在进行编辑的控件很简单,没有任何样式。当我在页面上添加任何Kendo控件时,我可以正确控制,例如DatePicker控件。因此风格和控制'js就在那里。唯一的问题是我没有在网格内部获得剑道控制。
Index.cshtml
@using Kendo.Mvc.UI
@using KendoGrid.Models
@(Html.Kendo().Grid<Person>()
.Name("Grid")
.Columns(columns => {
columns.Bound(p => p.FirstName).Width(140);
columns.Bound(p => p.LastName).Width(140);
columns.Bound(p => p.DayOfBirth).Width(200);
columns.Bound(p => p.Age).Width(150);
columns.Command(command => command.Destroy()).Width(110);
})
.ToolBar(toolbar =>
{
toolbar.Create();
toolbar.Save();
})
.Editable(editable => editable.Mode(GridEditMode.InCell))
.Pageable()
.Sortable()
.Scrollable()
.DataSource(dataSource => dataSource
.Ajax()
.Batch(true)
.ServerOperation(false)
.Events(events => events.Error("error_handler"))
.Model(model => model.Id(p => p.Id))
.Read("Read", "Grid")
.Create("Create", "Grid")
.Update("Update", "Grid")
.Destroy("Destroy", "Grid")
)
)
<div style="margin-top: 20px">
@(Html.Kendo().DatePicker()
.Name("datepicker")
.Value("10/10/2011")
.HtmlAttributes(new { style = "width:150px" })
)
</div>
<script type="text/javascript">
function error_handler(e) {
if (e.errors) {
var message = "Errors:\n";
$.each(e.errors, function (key, value) {
if ('errors' in value) {
$.each(value.errors, function () {
message += this + "\n";
});
}
});
alert(message);
}
}
</script>
_Layout.cshtml
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta charset="utf-8" />
<title>@ViewBag.Title</title>
<link rel="stylesheet" href="@Url.Content("~/Content/kendo.common.min.css")">
<link rel="stylesheet" href="@Url.Content("~/Content/kendo.default.min.css")">
<link rel="stylesheet" href="@Url.Content("~/Content/examples-offline.min.css")">
<script src="@Url.Content("~/Scripts/jquery.min.js")"></script>
<script src="@Url.Content("~/Scripts/kendo.web.min.js")"></script>
<script src="@Url.Content("~/Scripts/kendo.aspnetmvc.min.js")"></script>
<script src="@Url.Content("~/Scripts/console.min.js")"></script>
<script src="@Url.Content("~/Scripts/prettify.min.js")"></script>
@RenderSection("HeadContent", false)
</head>
<body>
<div class="page">
<div id="example" class="k-content">
@RenderBody()
</div>
</div>
</body>
</html>
这就是ingrid DatePiker控件现在的样子
这就是DatePicker应该是这样的。
提前致谢。
此致 维拉德
答案 0 :(得分:1)
很可能您缺少 Views / Shared / EditorTemplates 文件夹下的EditorTemplates。检查它们包含的离线演示(因为您共享了屏幕截图;))。
使用相同的名称将它们复制并粘贴到您的解决方案中。