Kendo: Handling Errors in Ajax Data Requests

前端 未结 5 1113
耶瑟儿~
耶瑟儿~ 2020-12-17 08:23

Using Kendo UI in MVC4 I have a Grid that makes Ajax calls for data back into the Controller:

<         


        
相关标签:
5条回答
  • 2020-12-17 08:29

    To extend Drew's answer just a little bit: we usually want to roll back the change in the Kendo Grid also when an error occurs. Otherwise, if an error is thrown as an item is deleted from the grid, for instance, it will still appear to be deleted even though the error was thrown and a message was shown.

    This function also cancels the changes in any grids that are using the data source that threw an error:

    function onError(e, status) {
    
        // Cancel changes on any grids on the page that are using this data source
        $('.k-grid').each(function (item) {
            var grid = $(this).data("kendoGrid");
            if (e.sender === grid.dataSource) {
                grid.cancelChanges();
            }
        });
    
        if (e.status == "customerror") {
            alert(e.errors);
        }
        else {
            alert("Generic server error.");
        }
    
    }
    
    0 讨论(0)
  • 2020-12-17 08:32

    How about

    throw new HttpResponseException(HttpStatusCode.BadRequest);
    
    0 讨论(0)
  • 2020-12-17 08:46

    Try to raise the exception and check whether it is prompting an alert message or not.

    For Kendo grid, there is error event which might be helpful for you.

    http://docs.kendoui.com/documentation/getting-started/using-kendo-with/aspnet-mvc/migration/widgets/grid

    We used telerik mvc grids which automatically displays alert messages if there is any error while binding.

    http://www.telerik.com/community/forums/aspnet-mvc/grid/exception-handling.aspx

    http://www.telerik.com/community/forums/aspnet-mvc/grid/how-to-do-error-handling-in-gridaction-methods.aspx

    0 讨论(0)
  • 2020-12-17 08:48

    Found it, Kendo supports it by just adding a Event to the DataSource the JS function to call. That's it.

      .DataSource(dataSource => dataSource
          .Ajax()
          .Events(events => events.Error("onError"))
          .Read(read => read.Action("SearchUser_Read", "Search").Data("parentModel"))
      )
    
    <script> 
        function onError(e, status) {
              alert("A server error has occurred!");
    }
    </script>
    
    0 讨论(0)
  • 2020-12-17 08:52

    If you need to display an error message from the server then you can do it by returning a DataSourceResult object with only its Errors property set:

    return this.Json(new DataSourceResult
                {
                    Errors = "my custom error"
                });
    

    And pick it up on the client by using this (referenced by the .Events(events => events.Error("onError")) line):

    function onError(e, status) {
        if (e.status == "customerror") {
            alert(e.errors);
        }
        else {
            alert("Generic server error.");
        }
    }
    
    0 讨论(0)
提交回复
热议问题