首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >telerik-grid onRowSelect如何获取id?

telerik-grid onRowSelect如何获取id?
EN

Stack Overflow用户
提问于 2010-12-10 20:56:32
回答 4查看 10.6K关注 0票数 4

大家好,我是asp.net、mvc和telerik控件方面的新手。当我点击行时如何获得o.Id的值?

代码语言:javascript
复制
 <%= Html.Telerik().Grid(Model)                    
                    .Name("RolesGrid")
                    .DataKeys(keys => keys.Add(o => o.Id))                               
                    .Selectable()                    
                    .Columns(columns =>
                    {
                        columns.Bound(o => o.Name);
                        columns.Bound(o => o.Description);

                    })
                    .Pageable()                       
                    .ClientEvents(events => events                    
                    .OnRowSelect("onRowSelect"))

             %>

在js代码中:

代码语言:javascript
复制
 function onRowSelect(e)   {
        var ordersGrid = $('#RolesGrid').data('tGrid');  
        var row = e.row;
        var dataItem = ordersGrid.dataItem(row);
        alert(dataItem);
    }

但是dataItem为空,并且在生成的html文件中没有id值。感谢并为我糟糕的英语道歉

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2011-06-17 15:53:57

所以毕竟我有最好的方法来获取id:

  1. 将onRowSelect函数绑定到您的网格
  2. 用onRowSelect编写下一段代码

var jQuery('#MyGridId').data('tGrid').dataItem(e.row);=var dataItem (dataItem‘’Id‘);

dataItem是一种具有格网模型所有属性的地图,因此您可以获得所需的所有

就这些了,谢谢

票数 12
EN

Stack Overflow用户

发布于 2011-02-09 23:20:41

来自telerik grid demo

您必须将Id作为隐藏列放在telerik网格中。

代码语言:javascript
复制
// ...
.DataKeys(keys => keys.Add(o => o.Id))                               
.Selectable()
.Columns(columns =>
    {
        columns.Bound(o => o.Id).Hidden();
        columns.Bound(o => o.Name);
        columns.Bound(o => o.Description);
    })
// ...
.ClientEvents(events => events.OnRowSelect("onRowSelect"))

它将呈现一个

代码语言:javascript
复制
<td style="display: none; ...">...</td>

然后你就会得到这样的结果:

代码语言:javascript
复制
function onRowSelect(e)   {
    var id = e.row.cells[0].innerHTML;
    // ...
}

备注:

  • 我知道,这很难看。
  • 我不明白,如果没有记录在案的方法来获取定义的键值,为什么telerik会强制您调用.DataKeys(...)方法。
  • 如果使用分组或其他功能,则会变得更加棘手,因为隐藏列的位置根据分组telerik的不同而不同
票数 10
EN

Stack Overflow用户

发布于 2015-06-24 23:48:15

我发现了一种更优雅的方法,借鉴了mmutilva的答案。

首先,以相同的方式放入隐藏列和更改事件:

代码语言:javascript
复制
.DataKeys(keys => keys.Add(o => o.Id))                               
.Selectable()
.Columns(columns =>
    {
        columns.Bound(o => o.Id).Hidden();
        columns.Bound(o => o.Name);
        columns.Bound(o => o.Description);
    })
.ClientEvents(events => events.OnRowSelect("onRowSelect"))

但是在javascript函数中,有一种更好的方法来实际选择对象,然后选择隐藏的行:

代码语言:javascript
复制
    function onRowSelect(e)   {
        var grid = e.sender;
        var currentitem = grid.dataItem(this.select());
        var Id = currentitem.Id;
        //then do whatever with the ID variable
    }

Source

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4409012

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档