Binding grid reload events
Name Surname Marital status Time stamp
Joe Crosswave Married 10/23/2019 5:42:24 AM
Merry Lisel Widowed 10/23/2019 5:42:24 AM
Henry Crux Single 10/23/2019 5:42:24 AM
Cody Jurut 10/23/2019 5:42:24 AM
Simon Scranton Single 10/23/2019 5:42:24 AM
Leena Laurent Divorced 10/23/2019 5:42:24 AM
Ode Cosmides Married 10/23/2019 5:42:24 AM
Diandra Mizner Single 10/23/2019 5:42:24 AM
Pete Cassel Married 10/23/2019 5:42:24 AM
Nicky Tremblay Married 10/23/2019 5:42:24 AM
Main view

@Html.AjaxGrid(Url.Action("IndexGrid"))

_IndexGrid partial view

@model IEnumerable<Person>

@* Should only include grid declaration *@

@(Html
    .Grid(Model)
    .Build(columns =>
    {
        columns.Add(model => model.Name).Titled("Name");
        columns.Add(model => model.Surname).Titled("Surname");
        columns.Add(model => model.MaritalStatus).Titled("Marital status");

        columns.Add(model => DateTime.Now).Titled("Time stamp");
    })
)

Javascript

document.addEventListener('reloadstart', function (e) {
    console.log('grid: ', e.detail.grid);
});

document.addEventListener('reloadend', function (e) {
    console.log('grid: ', e.detail.grid);
});

document.addEventListener('reloadfail', function (e) {
    console.log('grid: ', e.detail.grid);
    console.log('failed ajax response result: ', e.detail.result);
});

Controller

[HttpGet]
public ViewResult Index()
{
    return View();
}

[HttpGet]
public PartialViewResult IndexGrid()
{
    return PartialView("_IndexGrid", repository.GetPeople());
}