Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Problem z ajax przy while
Forum PHP.pl > Forum > XML, AJAX
diamondking
W PHP mam funkcję WHILE, która generuje mnie listę przycisków i każdy ma unikatową wartość:

  1. <button id="btnwykonaj" class="btn btn-primary btn-sm btnwykonaj" value="'.$rekord['id'].'">Odbierz nagrodę</button>


Mam też AJAX:

  1. $('#btnwykonaj').click(function(){
  2. var id = $(this).val();
  3.  
  4. //Stop the form from submitting itself to the server.
  5. e.preventDefault();
  6. var id = id;
  7. $.ajax({
  8. type: "POST",
  9. url: 'ajax/nagroda.php',
  10. data: {id: id},
  11. success: function(data){
  12.  
  13.  
  14. if(data.trim()=='ok'){
  15. toastr.success('Nagroda kupiona', 'Sukces');
  16.  
  17. setTimeout(function(){
  18. $(location).attr('href', 'nagrody.php');
  19. }, 2000);
  20.  
  21.  
  22. }
  23.  
  24.  
  25.  
  26.  
  27. }
  28. });
  29. });


ale skrypt działa tylko dla pierwszego przycisku sad.gif
wiecie w czym może być problem?

EDIT

Poradziłem sobie w ten sposób:

  1. <button onclick="checkValue(this);" class="btn btn-primary btn-sm btnwykonaj" value="'.$rekord['id'].'">Odbierz nagrodę</button>



  1. <script>
  2. function checkValue(ele) {
  3. var nagrodaid = ele.value;
  4.  
  5. $.ajax({
  6. type: "POST",
  7. url: 'ajax/nagroda.php',
  8. data: {id: nagrodaid},
  9. success: function(data){
  10.  
  11.  
  12. if(data.trim()=='ok'){
  13. toastr.success('Kupiono nagrodę', 'Sukces');
  14.  
  15. setTimeout(function(){
  16. $(location).attr('href', 'nagrody.php');
  17. }, 2000);
  18.  
  19.  
  20. }
  21.  
  22. }
  23. });
  24.  
  25. }
  26. </script>
LowiczakPL
było

Kod
<button id="btnwykonaj"

$('#btnwykonaj').click(function(){


ID musi być unikalne czyli wystepuje tylko 1 raz, więc Twoj kod reagował na klik o ID btnwykonaj

jeśli kod ma reagować na więcej kliknięć robisz to jako nazwę klasy selektora czyli

Kod
<button class="btnwykonaj"

$('.btnwykonaj').click(function(){



Nie rób w ten sposób aby dodawać onclick, to obejście a nie rozwiązanie problemu. Zapomnij że istnieje onclick.

Obejścia problemów powodują nawarstwianie się problemów.
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.