Drukowana wersja tematu

Kliknij tu, aby zobaczyć temat w orginalnym formacie

Forum PHP.pl _ XML, AJAX _ [jQuery, JS] Aktualizowanie sumy po wysłaniu formularza poprzez ajax

Napisany przez: oskarszlempo 16.04.2020, 00:27:07

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

Napisany przez: trueblue 16.04.2020, 09:18:59

Te plusy przed zmiennymi są niepotrzebne.
Sprawdź co jest w data.price, czy nie jest to czasem liczba z przecinkiem albo z postfixem "zł".

Napisany przez: oskarszlempo 16.04.2020, 12:58:34

Cytat(trueblue @ 16.04.2020, 10:18:59 ) *
Te plusy przed zmiennymi są niepotrzebne.
Sprawdź co jest w data.price, czy nie jest to czasem liczba z przecinkiem albo z postfixem "zł".



data.price zwraca decimal(9,2), czyli np 1.00, 2.00, 4.59, 2.35

Jak robię:
[JAVASCRIPT] pobierz, plaintext
  1. $("#suma").text(first + second);
[JAVASCRIPT] pobierz, plaintext


To na stronie po każdym wysłanym formularzu wygląda to tak:
0.001.492.394.5949.99

Czyli zamiast kwoty się sumować to one się dodają na końcu

Napisany przez: viking 16.04.2020, 13:16:52

Kwoty przepuść przez parseFloat. https://developer.mozilla.org/pl/docs/Web/JavaScript/Referencje/Obiekty/parseFloat

Napisany przez: trueblue 16.04.2020, 13:17:11

parseFloat(first) + parseFloat(second);

Napisany przez: oskarszlempo 16.04.2020, 13:58:19

[JAVASCRIPT] pobierz, plaintext
  1. var first = $(".suma").text();
  2. var second = data.price;
  3.  
  4. console.log('First: ' + first);
  5. console.log('Second: ' + second);
  6. console.log('Total: ' + parseFloat(first) + parseFloat(second));
[JAVASCRIPT] pobierz, plaintext


Zwraca:

Napisany przez: nospor 16.04.2020, 14:03:26

console.log(parseFloat(first) + parseFloat(second));
console.log('Total: ' + (parseFloat(first) + parseFloat(second)));

Napisany przez: oskarszlempo 16.04.2020, 14:18:11

Cytat(nospor @ 16.04.2020, 15:03:26 ) *
console.log(parseFloat(first) + parseFloat(second));
console.log('Total: ' + (parseFloat(first) + parseFloat(second)));


NaN
Total: NaN

--

Może da się to jakoś inaczej zrobić, aby nie pobierać wartości z diva tylko z jakiejś zmiennej która się będzie aktualizowała po każdym wysłanym formularzu?

Napisany przez: nospor 16.04.2020, 14:21:50

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.

Napisany przez: oskarszlempo 17.04.2020, 22:27:15

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.. :/

Napisany przez: nospor 18.04.2020, 15:33:24

alert(data.price);
alert(parseFloat(data.price));

Napisany przez: oskarszlempo 18.04.2020, 15:48:53

Cytat(nospor @ 18.04.2020, 16:33:24 ) *
alert(data.price);
alert(parseFloat(data.price));



Napisany przez: nospor 20.04.2020, 09:44:47

Ale czemy widze wynik tylko jednego alert?

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)