2013-06-24 1 views
7

scrivo questo codice per creare griglia con kendo Ui in asp.net mvccome ottenere la riga di chiave selezionato nella griglia di kendo ui

@(Html.Kendo().Grid(Model) 
     .Name("Grid") 

     .Columns(columns => 
        { 
         columns.Bound(p => p.Id).Groupable(false).Visible(false); 
         columns.Bound(p => p.BrandName); 
         columns.Bound(p => p.BrandAbbr); 
         columns.Bound(p => p.SrcImage); 

         columns.Command(command => command.Custom("ViewDetails").Click("showDetails")); 
         }) 

    .ToolBar(toolbar => 
        { 
         toolbar.Custom().Action("Create","Users").Text("add");       
        } 
     ) 
     .Groupable() 
     .Pageable() 
     .Sortable() 
.Scrollable() 

     .Filterable() 
     .HtmlAttributes(new {style = "height:500px;"}) 
     .Selectable(selectable => selectable 
      .Mode(GridSelectionMode.Multiple) 
      .Type(GridSelectionType.Row)) 

     .DataSource(dataSource => dataSource 
            .Server()       
            .Model(model => model.Id(item => item.Id)) 

    )) 

voglio quando l'utente clicca sul ViewDetails allerta BrandId valore Colonna, ti prego, aiutami .thanks tutti

risposta

12

Hai solo bisogno di aggiungere la funzione javascript.

<script type="text/javascript"> 
    function showDetails(e) { 
     e.preventDefault(); 
     var dataItem = this.dataItem($(e.currentTarget).closest("tr")); 
     alert(dataItem.Id); //considering Id = BrandId 
    } 
</script> 

Ecco la demo di Kendo Grid Custom Command

4

anche ho usato questo successo:

<script type="text/javascript"> 

function showDetails(e) 
{ 
e.preventDefaults(); 
var grid = $("#Grid").data("kendoGrid"); 

    var selectedItem = grid.dataItem(grid.select()); 


//you can get the value of any column after that 

alert("Brand Id is : " + selectedItem.Id); 
alert("Brand Name is: " + selectedItem.BrandName); 

} 

</script> 
+3

'grid.select()' funziona solo se la griglia è '.Selectable()' – Salar