La llamada AJAX congela el navegador por un momento mientras recibe respuesta y ejecuta el éxito

Estoy haciendo una llamada AJAX a mi servidor web que obtiene una gran cantidad de datos. Muestro una imagen de carga que gira mientras se ejecuta la llamada ajax y luego se desvanece.

Lo que he notado es que todos los navegadores en esta llamada en particular dejarán de responder durante aproximadamente 7 segundos. Dicho esto, la imagen de carga NO gira como lo que había planeado mientras se estaba produciendo la recuperación.

No sabía si esto era algo que sucedía o si había una forma de hacerlo, en cierto sentido, podría haber una bifurcación () para que haga 1 cosa, mientras mi ícono de carga aún gira.

¿Por qué? Ideas?

A continuación se muestra el código que alguien quería ver:

$("div.loadingImage").fadeIn(500);//.show();
            setTimeout(function(){
            $.ajax({
                type: "POST",
                url: WEBSERVICE_URL + "/getChildrenFromTelTree",
                dataType: "json",
                async: true,
                contentType: "application/json",
                data: JSON.stringify({
                    "pText": parentText,
                    "pValue": parentValue,
                    "pr_id": LOGGED_IN_PR_ID,
                    "query_input": $("#queryInput").val()
                }),
                success: function (result, textStatus, jqXHR) {
                    //alert("winning");
                    //var childNodes = eval(result["getChildrenFromTelTreeResult"]);
                    if (result.getChildrenFromTelTreeResult == "") {
                        alert("No Children");
                    } else {
                        var childNodes = JSON.parse(result.getChildrenFromTelTreeResult);
                        var newChild;
                        //alert('pText: '+parentText+"\npValue: "+parentValue+"\nPorofileID: "+ LOGGED_IN_PR_ID+"\n\nFilter Input; "+$("#queryInput").val() );
                        //alert(childNodes.length);
                        for (var i = 0; i < childNodes.length; i++) {
                            TV.trackChanges();
                            newChild = new Telerik.Web.UI.RadTreeNode();
                            newChild.set_text(childNodes[i].pText);
                            newChild.set_value(childNodes[i].pValue);
                            //confirmed that newChild is set to ServerSide through debug and get_expandMode();
                            parentNode.get_nodes().add(newChild);
                            TV.commitChanges();
                            var parts = childNodes[i].pValue.split(",");
                            if (parts[0] != "{fe_id}" && parts[0] != "{un_fe_id}") {
                                newChild.set_expandMode(Telerik.Web.UI.TreeNodeExpandMode.ServerSide);
                            }
                        }
                    }
                    //TV.expand();
                    //recurseStart(TV);
                },
                error: function (xhr, status, message) {
                    alert("errrrrror");
                }
            }).always(function () {
                    $("div.loadingImage").fadeOut();
                });
                },500);

Un empleado mío se dio cuenta de este problema y sugirió que agregue un setTimeout (function () {..}, 500); pero no soluciona el problema en cuestión, por lo que lo más probable es que se elimine.

Respuestas a la pregunta(1)

Su respuesta a la pregunta