Wykonuję połączenie AJAX z moim serwerem, który pobiera dużo danych. Pokaż obraz ładujący, który obraca się podczas wykonywania wywołania ajax, a następnie znika.Połączenie AJAX zamraża przeglądarkę przez chwilę, gdy otrzymuje odpowiedź i wykonuje sukces
Zauważyłem, że wszystkie przeglądarki w tym konkretnym telefonie sprawiają, że nie reaguje przez około 7 sekund. W związku z tym obraz ładujący NIE wiruje jak to, co zaplanowałem podczas pobierania.
Nie wiedziałem, czy to jest coś, co się dzieje, czy jest jakiś sposób, aby w pewnym sensie spowodować rozwidlenie(), tak że robi to jedno, podczas gdy moja ikona ładowania wciąż się kręci.
Myśli? Pomysły?
poniżej jest kod jak ktoś chciał to zobaczyć:
$("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);
corworker kopalni zauważył ten problem i zaproponował dodać setTimeout (function() {..}, 500); ale nie rozwiązuje problemu, więc najprawdopodobniej zostanie usunięty.
Jaka jest "długość treści" odpowiedzi? –
Nie używasz 'async: false' right? –
jest twoim serwerem WWW na localhost? albo jego wywołanie synchroniczne, albo skrypt back-end robi coś szalonego –