Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Opóźniona funkcja JQuery + AJAX + PHP
Forum PHP.pl > Forum > XML, AJAX
mariolita
Witam Was serdecznie. Stworzyłem taką funkcję

mam 150 danych (żałóżmy że to liczy są - 150 różnych liczb) funkcja po stronie przeglądarki jquery wysyła osobno -> while - każdą liczbę wysyłka do pliku PHP (w php skrypcie zmienna wysłana z przeglądarki jest szukana odpowidz itd itp) Ajaxem jako POST i odbiera odpowiedź i odowiedź umieszcza w konkretnym miejscu. Proces ten trwa trochę czasu - jest sporo danych - wiem że to chwilę musi potrwać i bardziej skryptu uprościć się nie da. Na końcu funckji już po while ustawiłem żeby $("#status_operacji").text("KONIEC") mnie informwał czy funkcja się skończyła czy nie. Ale niestety KONIEC pojawia się odrazu a funkcja Ajax nadal trwa i nadal dane są zbierane. Co zrobić żeby KONIEC pokazał się dopiero po skończonej funkcji? Pozdrawiam
kayman
można to zrobić na 1000 sposobów np dodatkowa zmienna zliczająca odpowiedzi z POST, tablica opóźniana przy odpowiedzi z POST

mariolita
  1. <!--- REFRESH ALL --->
  2.  
  3. $("#refresh").click( function() {
  4.  
  5. $.get("php_files/noeosu.php", function(noeosu) {
  6.  
  7. i = 0;
  8.  
  9. split_noeosu = noeosu.split(",");
  10.  
  11. numbers = split_noeosu[split_noeosu.length-1];
  12.  
  13. while (i < numbers) {
  14.  
  15. this_number = split_noeosu[i];
  16.  
  17. <!--- CHECK NUMBER STATUS --------------------------------!>
  18.  
  19. $.ajax({
  20.  
  21. type: "POST",
  22.  
  23. url: "/php_files/checkstatus.php",
  24.  
  25. data: "checkStatus=" + this_number,
  26.  
  27. success: function(checkedStatus) {
  28.  
  29. $("#header_left").append(checkedStatus);
  30.  
  31. if(i == numbers) {
  32.  
  33. $("#list").text("KONIEC");
  34.  
  35. }
  36.  
  37. }
  38.  
  39. });
  40.  
  41. <!--- CHECK ALL --------------------------------!>
  42.  
  43. i++;
  44.  
  45. }
  46.  
  47.  
  48.  
  49. });
  50.  
  51. });
kayman
Kod
if(i == numbers) {
$("#list").text("KONIEC");
}


napisane jest -> jeżeli ilość wysłanych == ilość do wysłania to koniec

a ile odebranych nie wiadomo czyli zły warunek
mariolita
fakt, lecz sprawdziłem każdą linię i okazuje się że tam gdzie Ajax - zanika stopniowanie i++ i odrazu jest maxymalna liczba.

async: false

dodane do Ajaxa pomogło smile.gif
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2024 Invision Power Services, Inc.