Kendo Mvc Grid Custom Binding Read Again
-                   
- Updated date Dec 04, 2020
- 235k
-                                                   4                                
In this article, we will learn how to bind information to Kendo Grid in MVC using multiple ways.
Introduction
Many times, while working with Grid, nosotros need to testify the event into a GridView in different situations.
What is Kendo Filigree?
The Kendo UI Filigree is a powerful widget that allows y'all to visualize and edit information via its table representation. It provides many options, such as paging, sorting, filtering, grouping, and editing, which decide the way data is presented and manipulated.
The Filigree can be leap to local or remote data by using the Kendo UI DataSource component.
Scenario I Bind data to Kendo Filigree by using AJAX Read action method.
Scenario II Alter the datasource on change result of any HTML controls.
                        Scenario I              
                                      
            Unremarkably, a developer can bind the data to Grid past using AJAX Read method.
This read method is ActionResult method in MVC which volition return JSON DataSourceResult & direclty bind the data to Grid.
                                      Note
                            
            As well, the programmer can pass parameters to this read method. Suppose below is our read method.
- Read(read => read.Action( "BindGrid" , "Home" ).Data( "SortByCompanyId" ))
In the above line, my JavaScript part proper name is SortByCompanyId which volition return company id. On that footing, nosotros can pass parameter to our action method in Controller.
- public ActionResult BindGrid([DataSourceRequest]DataSourceRequest request, string companyId)
- {
- }
Our JavaScript role is like the following.
- <script type= "text/javascript" >
- function SortByCompanyId() {
- var cId = 25;
- render {
- companyId: cId
- }
- }
- </script>
Step 1Create a Model, give it a name as Company, and declare some backdrop into it.
- public class Company
- {
- public int Id { get ; set ; }
- public string Proper name { get ; set ; }
- public int ? CompanyId { get ; gear up ; }
- }
Step 2Now, create a Controller, give it name every bit HomeController. In this, create a action method as Alphabetize() which will return a View. On this View, write some code to bind data into the Grid View past using the above Model.
- @model Grid.Models.Visitor
- @using System.Web.Optimization
- @using Kendo.Mvc.UI
- @using Kendo.Mvc.Extensions
- @{
- Layout = "~/Views/Shared/_Layout.cshtml" ;
- }
- < div way = "width:lx%;height:100%" >
- @(Html.Kendo().Grid< Grid.Models.Company > ()
- .Proper noun("BindGridUsingRead")
- .Columns(columns = >
- {
- columns.Bound(p = > p.Id).Width(15).Championship("Sr. No.").Filterable(false);
- columns.Bound(p = > p.Name).Title("Proper name").Width(30).Filterable(false);
- columns.Bound(p = > p.CompanyId).Championship("Visitor Id").Width(15).Filterable(faux);
- })
- .Scrollable()
- .Pageable(ten = > 10.PageSizes(new Listing < object > { 10, twenty, 100, 200, 500, "all" }).Refresh(true))
- .Filterable(ftp = > ftp.Way(GridFilterMode.Row))
- .Resizable(resize = > resize.Columns(true))
- .HtmlAttributes(new {mode = "height: 100%" })
- .Selectable()
- .DataSource(dataSource = > dataSource
- .Ajax()
- .Model(model = > model.Id( p = > p.Id))
- .ServerOperation(simulated)
- .Read(read = > read.Activity("BindGrid", "Habitation"))
- )
- )
- </ div >
Pace 3In Controller, write method which will bind the data to Grid by using Ajax Read activeness method. At present, write some action methods named equally BindGrid (to demark the JSON data to Grid). I am going to bind some difficult coded values by using action method GetGridData() using Company model which will render IEnumerable List.
- public ActionResult Index()
- {
- return View();
- }
- public ActionResult BindGrid([DataSourceRequest]DataSourceRequest request)
- {
- try
- {
- decimal companyId = 0;
- List<Models.Company> lst =new Listing<Models.Company>();
- lst = GetGridData(Convert.ToInt32(companyId)).ToList();
- DataSourceResult result = lst.ToDataSourceResult(asking, p =>new Models.Visitor
- {
- Id = p.Id,
- Name = p.Name,
- CompanyId = p.CompanyId,
- });
- return Json(result, JsonRequestBehavior.AllowGet);
- }
- catch (Exception ex)
- {
- var errorMsg = ex.Bulletin.ToString();
- return Json(errorMsg, JsonRequestBehavior.AllowGet);
- }
- }
- public IEnumerable<Models.Company> GetGridData( decimal companyId)
- {
- List<Models.Company> objCmp =new List<Models.Company>();
- List<Models.Company> listCompany =new List<Models.Company>();
- objCmp.Add together(new Models.Company() { Id = 1, Name = "Rupesh Kahane" , CompanyId = xx });
- objCmp.Add together(new Models.Company() { Id = 2, Name = "Vithal Wadje" , CompanyId = 40 });
- objCmp.Add together(new Models.Company() { Id = three, Name = "Jeetendra Gund" , CompanyId = 30 });
- objCmp.Add(new Models.Company() { Id = iv, Name = "Ashish Mane" , CompanyId = 15 });
- objCmp.Add(new Models.Company() { Id = 5, Name = "Rinku Kulkarni" , CompanyId = 18 });
- objCmp.Add(new Models.Company() { Id = six, Name = "Priyanka Jain" , CompanyId = 22 });
- if (companyId > 0)
- {
- listCompany = objCmp.ToList().Where(a => a.CompanyId <= companyId).ToList();
- render listCompany.AsEnumerable();
- }
- render objCmp.ToList().AsEnumerable();
- }
Step 4Here is the outcome after running our solution.
                                  
                 
                
                                  
                  Scenario II
                                                  
                While working with html controls or forms, there are some situations, like we need to bind the data to Filigree on modify event of controls or we need to apply some custom filters, on search push button click event, we are applying these filters that change the datasource on modify event of any html control.
                                                  Note
                                    
                There is a congenital-in functionality every bit well to filter Grid information from column values. Hither, we are using custom filters.
Suppose, the user entered some integer value & we need the data where company id is less than input value in on alter event of control. So we take i textbox & volition write on change event lawmaking into a javascript by using transport.options.read method. We are passing read method URL & input value to out action method.
Step 1Equally I explained in scenario I, we are adding but one textbox &JS file which contains change event function to our View. Add together some JavaScript lawmaking above this which will incorporate bind grid method as -
- <script type= "text/javascript" >
- var gridObject;
- var readURL = new Array();
- readURL[0] ="/Habitation/BindGrid" ;
- readURL[1] ="/Habitation/BindGridOnSearch?companyId=" ;
- </script>
Now, our View page will expect similar the post-obit.
- @model Grid.Models.Company
- @using Organization.Spider web.Optimization
- @using Kendo.Mvc.UI
- @using Kendo.Mvc.Extensions
- @{
- Layout = "~/Views/Shared/_Layout.cshtml" ;
- }
- < script blazon = "text/javascript" >
- var gridObject;
- varreadURL = new Array();
- readURL[0] = "/Home/BindGrid";
- readURL[ane] = "/Home/BindGridOnSearch?companyId =";
- </ script >
- < div >
- < div class = "box-header with-border" >
- < div course = "col-xs-12" >
- < div class = "col-xs-4 martop" way = "text-align:right;width:22%" >
- @(Html.Kendo().TextBoxFor(model = > model.CompanyId)
- .Proper noun("CompanyId")
- .HtmlAttributes(new {placeholder = "Search By Company Id" , @ autocomplete = "off" , @ form = "col-sm-12" , style = "width:100%" , maxlength = 200 })
- )
- </ div >
- </ div >
- </ div >
- </ div >
- < br />
- < div style = "width:60%;tiptop:100%" >
- @(Html.Kendo().Grid< Filigree.Models.Company > ()
- .Name("BindGridUsingRead")
- .Columns(columns = >
- {
- columns.Bound(p = > p.Id).Width(15).Championship("Sr. No.").Filterable(fake);
- columns.Bound(p = > p.Name).Title("Proper name").Width(30).Filterable(false);
- columns.Leap(p = > p.CompanyId).Title("Visitor Id").Width(xv).Filterable(false);
- })
- .Scrollable()
- .Pageable(x = > x.PageSizes(new Listing < object > { 10, 20, 100, 200, 500, "all" }).Refresh(true))
- .Filterable(ftp = > ftp.Mode(GridFilterMode.Row))
- .Resizable(resize = > resize.Columns(true))
- .HtmlAttributes(new {style = "height: 100%" })
- .Selectable()
- .DataSource(dataSource = > dataSource
- .Ajax()
- .Model(model = > model.Id( p = > p.Id))
- .ServerOperation(fake)
- .Read(read = > read.Activity("BindGrid", "Dwelling house"))
- )
- )
- </ div >
- < script src = "~/Scripts/Custom/Home.js" > </ script >
Step 2Now, write lawmaking on change event of textbox into JavaScript Home.js file. In our JS file on windows.load method, we tin get data of Filigree into a our global variable.
- $(window).load( role () {
- gridObject = $("#BindGridUsingRead" ).information( "kendoGrid" );
- });
- $(certificate).set(function () {
- $('#CompanyId' ).on( 'change' , part () {
- var cmpId = $( "input[id='CompanyId']" ).val();
- gridObject.dataSource.ship.options.read.url = readURL[1] + cmpId;
- gridObject.dataSource.read();
- });
- });
Step iiiWrite some code into Controller confronting these read methods.
- public ActionResult BindGridOnSearch([DataSourceRequest]DataSourceRequest request, string companyId)
- {
- try
- {
- Listing<Models.Company> list =new List<Models.Visitor>();
- list = GetGridData(Catechumen.ToInt32(companyId)).ToList();
- DataSourceResult result = listing.ToDataSourceResult(request, p =>new Models.Visitor
- {
- Id = p.Id,
- Name = p.Name,
- CompanyId = p.CompanyId,
- });
- return Json(issue, JsonRequestBehavior.AllowGet);
- }
- catch (Exception ex)
- {
- var errorMsg = ex.Message.ToString();
- return Json(errorMsg, JsonRequestBehavior.AllowGet);
- }
- }
Pace 4Here is the result after running our solution (if we enter 25 into input box).
                 
                              
Summary
In this article, you learned the basics of how to bind information to Kendo Grid in MVC using multiple methods.
Source: https://www.c-sharpcorner.com/article/multiple-ways-to-bind-data-to-kendo-grid-in-mvc/
0 Response to "Kendo Mvc Grid Custom Binding Read Again"
Mag-post ng isang Komento