我正在开发一个简单的项目来显示Kendo Grid中的事物列表。 当用户单击Kendo Grid的一行时,我想显示与该行相关的值。
到目前为止,网格工作正常。它变得可选,它的鼠标单击事件会触发JavaScript函数。
网格看起来像这样:
@(Html.Kendo().Grid<MyProject.Models.Object>()
.BindTo((IEnumerable<MyProject.Models.Object>)Model)
.Name("Object")
.Columns(columns =>
{
columns.Bound(p => p.ObjectID).Title("ID").Hidden().HtmlAttributes(new { id="ID" });
columns.Bound(p => p.DmObjectName.DmObjectNameDesc).Title("Object Name");
columns.Bound(p => p.DmObjectType.DmObjectTypeDesc).Title("Object Type");
columns.Bound(p => p.DmObjectState.DmObjectStateDesc).Title("Storage State");
})
.Pageable(pager => pager
.PageSizes(new[] { 5, 10, 20, 50, 100, 1000 }))
.Filterable(ftb => ftb.Mode(GridFilterMode.Row))
.Selectable(selectable => selectable
.Mode(GridSelectionMode.Single)
.Type(GridSelectionType.Row)
)
.Sortable()
.Reorderable(reorder => reorder.Columns(true))
.Resizable(resize => resize.Columns(true))
.ColumnMenu()
.DataSource(dataSource => dataSource
.Server()
.Model(model => model.Id(p => p.ObjectID)
))
.Events(e => e.Change("Grid_OnRowSelect"))
)
标签和文本框:
<fieldset>
<legend accesskey="H">Object Detail</legend>
<table border="0" style="width: 95%; margin: 0 auto; border-collapse: collapse; border: 0px solid black;">
<tr>
<td class="label">
@Html.Label("Object Name:", new { @class = "designschema" })
</td>
<td class="editor">
@Html.Kendo().MaskedTextBox().Name("ObjectName").Enable(false)
</td>
<td class="label">
@Html.Label("Max:", new { @class = "designschema" })
</td>
<td class="editor">
@Html.Kendo().MaskedTextBox().Name("Max").Enable(false)
</td>
<td class="label">
@Html.Label("Avg:", new { @class = "designschema" })
</td>
<td class="editor">
@Html.Kendo().MaskedTextBox().Name("Avg").Enable(false)
</td>
</tr>
<tr>
<td class="label">
@Html.Label("Fire", new { @class = "designschema" })
</td>
<td class="editor">
@Html.Kendo().MaskedTextBox().Name("Fire").Enable(false)
</td>
<td class="label">
@Html.Label("State", new { @class = "designschema" })
</td>
<td class="editor">
@Html.Kendo().MaskedTextBox().Name("State").Enable(false)
</td>
</tr>
<tr>
<td class="label">
@Html.Label("Health", new { @class = "designschema" })
</td>
<td class="editor">
@Html.Kendo().MaskedTextBox().Name("Health").Enable(false)
</td>
<td class="label">
@Html.Label("Location", new { @class = "designschema" })
</td>
<td class="editor">
@Html.Kendo().MaskedTextBox().Name("Location").Enable(false)
</td>
</tr>
<tr>
<td class="label">
@Html.Label("Reactivity", new { @class = "designschema" })
</td>
<td class="editor">
@Html.Kendo().MaskedTextBox().Name("Reactivity").Enable(false)
</td>
<td class="label">
@Html.Label("Container", new { @class = "designschema" })
</td>
<td class="editor">
@Html.Kendo().MaskedTextBox().Name("Container").Enable(false)
</td>
</tr>
<tr>
<td class="label">
@Html.Label("Special", new { @class = "designschema" })
</td>
<td class="editor">
@Html.Kendo().MaskedTextBox().Name("Special").Enable(false)
</td>
</tr>
</table>
</fieldset>
<fieldset>
<legend accesskey="N">Notes</legend>
<table border="0" style="width: 95%; margin: 0 auto; border-collapse: collapse; border: 0px solid black;">
<tr>
<td class="editor">
@Html.TextArea("Notes", new { @style = "resize: vertical; width: 100%; height: 20px" })
</td>
</tr>
</table>
</fieldset>
这是JavaScript:
<script>
function Grid_OnRowSelect() {
var row = this.select();
var id = row.data("ID");
}
</script>
我目前还没有超越这个目标,因为似乎row.data("ID")
无效。我在调试模式下运行了我的应用程序并捕获了var row
中的内容。
row
的值如下所示:
<tr class="k-state-selected" aria-selected="true">
<td id="ID" style="display:none">1</td>
<td>TEST</td>
<td>Object (Flammable)</td>
<td> </td>
<td> </td>
</tr>
所以行中选定的值是正确的。但是有一种从<td>, <tr>
中选择每个值的好方法吗?或者使用row.data("ID")
的好方法?
我还想将选定的值放入Kendo Grid正下方的文本框中。我认为有一种方法可以选择模型,而不是网格中的每个值,其名称为MyProject.Models.Object
,其中ID
与模型匹配。
你能给我一些接近和解决的好方法吗?我可以继续前进吗?
答案 0 :(得分:0)
您可以尝试使用kendo grid dataItem函数。在你的情况下,它将是:
var selectedItem = this.dataItem(this.select());
答案 1 :(得分:0)
这是documented:
使用Grid的MVC包装器时,Grid必须是Ajax绑定的,才能使dataItem()方法起作用。使用服务器绑定时,dataSource实例不包含序列化数据项。
您正在使用BindTo
,因此网格的html会在服务器上呈现,并且不会绑定到客户端的任何数据。您可以使用DataSource
,也可以手动执行所有操作。