Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [jQuery, JS] Aktualizowanie sumy po wysłaniu formularza poprzez ajax
oskarszlempo
post
Post #1





Grupa: Zarejestrowani
Postów: 10
Pomógł: 0
Dołączył: 5.06.2019

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


Cześć! Powiedzmy, że mam formularz z polem tekstowym barcode. Użytkownik wpisuje tam kod, który poprzez ajax jest wysyłany do api, a z niego otrzymuje się cenę, która powinna się wyświetlić w okienku typu alert, ale oprócz tego na stronie index.html jest wyświetlany div o nazwie suma z domyślną wartością 0.00. Jeśli użytkownik wyśle formularz to ta kwota powinna wzrosnąć o wartość odebraną z api.

Poradziłem sobie z wysłaniem zapytania do api i wyświetlam w alercie cenę, ale nie umiem zaktualizować łącznej sumy w divie.

[JAVASCRIPT] pobierz, plaintext
  1. $('form').submit(function(e) {
  2. var formData = {
  3. 'barcode': $('input[name=barcode]').val()
  4. };
  5. $.ajax({
  6. type: 'POST',
  7. url: 'barcode.php',
  8. data: formData,
  9. dataType: 'json',
  10. encode: true
  11. }).done(function(data) {
  12. alert('Cena: '+data.price);
  13. }).fail(function(data) {
  14. alert('fail');
  15. });
  16. });
[JAVASCRIPT] pobierz, plaintext


Przykład:

Suma: 0.00

Cena: 2.39

Suma: 2.39 (0.00+2.39)

Cena: 4.49

Suma: 6.88 (2.39+4.49)

--

Czy jest ktoś w stanie pomóc mi napisać taką funkcję, która będzie aktualizowała cenę po każdym wysłanym formularzu?

---

Robiąc to w ten sposób:

[JAVASCRIPT] pobierz, plaintext
  1. var first = $("#suma").text();
  2. var second = data.price;
  3.  
  4. $("#suma").text(+first + +second);
[JAVASCRIPT] pobierz, plaintext


Otrzymuję: NaN
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
nospor
post
Post #2





Grupa: Moderatorzy
Postów: 36 559
Pomógł: 6315
Dołączył: 27.12.2004




Cytat
aby nie pobierać wartości z diva tylko z jakiejś zmiennej która się będzie aktualizowała po każdym wysłanym formularzu?

No to wczym problem. Zrob dokladnie to co wlasnie napisales. Trzymaj to jeszcze w zmiennej globalnej i juz.
Go to the top of the page
+Quote Post
oskarszlempo
post
Post #3





Grupa: Zarejestrowani
Postów: 10
Pomógł: 0
Dołączył: 5.06.2019

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


Cytat(nospor @ 16.04.2020, 15:21:50 ) *
No to wczym problem. Zrob dokladnie to co wlasnie napisales. Trzymaj to jeszcze w zmiennej globalnej i juz.



[JAVASCRIPT] pobierz, plaintext
  1. let price = 0;
  2.  
  3. $('form').submit(function(e) {
  4. var formData = {
  5. 'barcode': $('input[name=barcode]').val()
  6. };
  7. $.ajax({
  8. type: 'POST',
  9. url: 'barcode.php',
  10. data: formData,
  11. dataType: 'json',
  12. encode: true
  13. }).done(function(data) {
  14. alert('Cena: '+data.price);
  15. price += parseFloat(data.price);
  16. $("#suma").text(price);
  17. }).fail(function(data) {
  18. alert('fail');
  19. });
  20. });
[JAVASCRIPT] pobierz, plaintext


Pokazuje mi NaN.. :/

Ten post edytował oskarszlempo 17.04.2020, 23:06:36
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: 8.10.2025 - 19:59