Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [JQUERY][AJAX] Zatrzymanie pętli
kwiatek5
post
Post #1





Grupa: Zarejestrowani
Postów: 36
Pomógł: 0
Dołączył: 26.01.2011

Ostrzeżenie: (0%)
-----


Witam,
ta pętla wykona się od razu, czyli prześle żądania ajaxa i się skończy, a w tle będą dołączane zwrócone wyniki.
1. Jak po przyciśnięciu np. buttona 'Stop' usunąć z kolejki pozostałe żądania, aby nie były już zwracane wyniki?
2. Czy jest jakiś sposób, aby wyniki były zwracane w takiej kolejności, jak wskazuje pętla bez blokowania przeglądarki?


  1. $.ajaxSetup({async:true});
  2.  
  3. $('#start').click(function(){
  4. for(var i=0; i<param.length; i++){
  5. $.post(
  6. 'adres.php',
  7. {param: param[i] },
  8. function(dane){
  9. $('#wynik').append(dane);
  10. }
  11. );
  12. }
  13. });


Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
kwiatek5
post
Post #2





Grupa: Zarejestrowani
Postów: 36
Pomógł: 0
Dołączył: 26.01.2011

Ostrzeżenie: (0%)
-----


Problem rozwiązany!
Po zwróceniu wyników wywołuję dopiero następnego requesta poprzez setTimeout().
Klikając przycisk STOP mam w_trakcie=false i wszystko się zatrzymuje.

[JAVASCRIPT] pobierz, plaintext
  1. function fun(p){
  2. $.ajax({
  3. ...,
  4. success: function(dane){
  5. p=...;
  6. if(p < ... && w_trakcie){
  7. setTimeout('fun('+p+')', 1);
  8. }
  9. else{
  10. w_trakcie=false;
  11. alert('Koniec');
  12. }
  13.  
  14. }
  15. });
  16. }
[JAVASCRIPT] pobierz, plaintext

Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 4.10.2025 - 21:07