New to Telerik UI for ASP.NET CoreStart a free 30-day trial

Local Binding

Updated on Oct 24, 2025

When configured for local binding, the ListView serializes the data as part of its DataSource and performs all data operations, such as paging, sorting, and filtering, on the client. This binding approach is beneficial if read-only data needs to be employed in the UI.

For a runnable example, refer to the demo on local binding of the ListView.

To configure the ListView for ASP.NET Core to do local binding:

  1. Define a model class or use an existing one from your application.

    C#
        public class EmployeeViewModel
        {
            public int EmployeeID
            {
                get;
                set;
            }
    
            [Required]
            public string FirstName
            {
                get;
                set;
            }
    
            [Required]
            public string LastName
            {
                get;
                set;
            }
    
            public string Title
            {
                get;
                set;
            }
    
    
            [Required]        
            public string Notes
            {
                get;
                set;
            }
        }
  2. Open the HomeController.cs and return an IEnumerable of the model type with the View. This is the View() which holds the ListView definition.

    C#
        public ActionResult Index()
        {
            // Returns a collection of EmployeeViewModels.
            var employees = Enumerable.Range(1, 9)
                .Select(new EmployeeViewModel{
                    EmployeeID = i,
                    FirstName = "FirstName" + i,
                    LastName = "LastName" + i,
                    Title = i % 2 == 0 ? "Manager": "CEO",
                    Notes = i % 2 == 0 ? "Manager at your service": "CEO at your service"
                }); // For the purposes of demonstration, you can mock the data, and copy and paste this snippet.
    
            return View(employees);
        }
  3. In the Index.cshtml view, configure the ListView to accept the model in its constructor and set ServerOperations(false).

    Razor
        @model IEnumerable<Kendo.Mvc.Examples.Models.EmployeeViewModel>
        
        <script type="text/x-kendo-tmpl" id="template">
            <div class="employee">
                 <div class="details">
                     <h2>#=FirstName# #=LastName#</h2>
                     <p>#=Title#</p>
                 </div>
                 <div class='bio'>
                   #=Notes#
                 </div>
            </div>
        </script>
    
        @(Html.Kendo().ListView(Model)
            .Name("listView")
            .TagName("div")
            .ClientTemplateId("template")
            .DataSource(dataSource => dataSource
                .Ajax()
                .ServerOperation(false)
                .PageSize(3)
            )
            .Pageable()
        )

See Also

In this article
See Also
Not finding the help you need?
Contact Support