Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [JS] Zaokrąglanie wyniku, Zaokrąglanie wyniku w JavaScript
pzebzda
post
Post #1





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

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


Witam.

Wstawiam kod mojego skryptu: (działa poprawnie, zaokrągla podane wartości z przecinkami dając wynik w liczbach całkowitych)

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
  2. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
  3.  
  4. <html xmlns="http://www.w3.org/1999/xhtml">
  5.  
  6. <head>
  7. <script type="text/javascript">
  8.  
  9. function licz(aform){
  10.  
  11. aform.liczba.value = parseFloat(aform.ilosc.value) +
  12.  
  13. parseFloat(aform.cena.value);
  14. }
  15. function zaokraglenie(liczba) {
  16. liczba = liczba * 100;
  17. var wynik = Math.round(liczba)/100;
  18. window(wynik);
  19. }
  20. </script>
  21. </head>
  22.  
  23. <body>
  24.  
  25. <form action="" name="xxx">
  26. <INPUT TYPE="text" NAME="ilosc" onKeyUp="licz(xxx);zaokraglenie(liczba.value);">
  27. <INPUT TYPE="text" NAME="cena" onKeyUp=" licz(xxx);zaokraglenie(liczba.value);">
  28. <INPUT TYPE="text" NAME="liczba">
  29.  
  30. </form>
  31.  
  32. </body>
  33.  
  34. </html>


Chcialbym aby skrypt obliczał mi nie tylko ilosc*cena=liczba ale i ilosc*cena*0.007=liczba

I tu już niestety wyniku mi nie zaokrągla.
0.007 to taki mój współczynnik.

Chcialbym otrzymywać zaokrąglaną wartość do całości w górę.

Np. więc 1,2=2

Proszę o pomoc. Ktoś ma pomysł jak to naprawić?

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





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

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


Cześć. Zamieniłem funkcje.

Podaję kod:

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
  2. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
  3.  
  4. <html xmlns="http://www.w3.org/1999/xhtml">
  5.  
  6. <head>
  7. <script type="text/javascript">
  8.  
  9. function licz(aform){
  10.  
  11. aform.liczba.value = parseFloat(aform.ilosc.value) * parseFloat(aform.cena.value) * 0.007;
  12. }
  13. function zaokraglenie(liczba) {
  14. liczba = liczba * 100;
  15. var wynik = Math.ceil(liczba)/100;
  16. window(wynik);
  17. }
  18. </script>
  19. </head>
  20.  
  21. <body>
  22.  
  23. <form action="" name="xxx">
  24. <INPUT TYPE="text" NAME="ilosc" onKeyUp="licz(xxx);zaokraglenie(liczba.value);">*
  25. <INPUT TYPE="text" NAME="cena" onKeyUp=" licz(xxx);zaokraglenie(liczba.value);">=
  26. <INPUT TYPE="text" NAME="liczba">
  27.  
  28. </form>
  29.  
  30. </body>
  31.  
  32. </html>


Niestety otrzymuję wynik w postaci:
(obrazek)

(IMG:http://niskoelektrotechnika.pl/obrazki/mnozenie.gif)

Coś robię nie tak... czy mógłbyś ewentualnie poprawić?
Go to the top of the page
+Quote Post
wiiir
post
Post #3





Grupa: Zarejestrowani
Postów: 260
Pomógł: 34
Dołączył: 22.02.2010

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


Cytat(pzebzda @ 5.09.2010, 21:08:02 ) *
  1. liczba = liczba * 100;
  2. var wynik = Math.ceil(liczba)/100;

przeciez liczba dalej ma taka sama wartosc, poza tym jesli chcesz to zaokraglic musisz dac calosc w nawiasie, czyli:
  1. var wynik = Math.ceil(liczba/100);
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: 3.10.2025 - 18:45