• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Problem ze skryptem.

Object Storage Arubacloud
0 głosów
302 wizyt
pytanie zadane 11 kwietnia 2022 w Sieci komputerowe, internet przez Grazyna2000 Nowicjusz (140 p.)
edycja 11 kwietnia 2022 przez Eryk Andrzejewski

Witam,czy wie ktos dla czego skrypt podczas klikania,żeby obliczal, wyskakuje NAN?

<!DOCTYPE html>
<html lang="pl">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
        body {
            font-family: Arial, Helvetica, sans-serif;
            background-color: brown;
            color: white;
        }

        div {
            text-align: center;
            font-size: 30px;
        }

        input {
            font-size: 20px;
        }

        button {
            font-size: 20px;
        }

        h1 {

        }
    </style>
  </head>
  <body>
      <div>
          <h1> PIZZERIA</h1>
        <form action="">
            <label for="kilometry">Ilość kilometrów</label>
            <input type="text" name="kilometry" id="kilometry" />
    
            <label for="zaznaczono">Jestem z Warszawy</label>
            <input type="checkbox" name="zaznaczono" id="zaznaczono" />
    
            <button onclick="pokazTekst()" type="button">Ile płacę?</button>
            <span id="tekst"></span>
          </form>
      </div>

      <script>
        var zaznaczono = document.getElementById("zaznaczono").checked;
        var tekst = document.getElementById("tekst");
        var dystans = document.getElementById("kilometry").value;
      
        function pokazTekst() {
          if (zaznaczono) {
            tekst.innerHTML = "Dowóz jest darmowy";
          } else {
            var cena = parseInt(dystans) * 2;
            tekst.innerHTML = "Dowóz będzie cię kosztował " + cena + " złotych";
          }
        }
      </script>
  </body>
</html>

 

1
komentarz 11 kwietnia 2022 przez Eryk Andrzejewski Mędrzec (164,260 p.)

Tak na przyszłość, bloczki kodu w stylu markdowna (czyli wewnątrz ```) nie działają, zamiast tego należy użyć bloczek kodu, oznaczony jako {...} code.

2 odpowiedzi

0 głosów
odpowiedź 11 kwietnia 2022 przez Eryk Andrzejewski Mędrzec (164,260 p.)

Problem polega na tym, że odczyt wartości z inputa wykonuje się tylko raz, podczas ładowania strony, a później po każdym kliknięciu w przycisk korzystasz z tej samej, wtedy odczytanej wartości. A trzeba zauważyć, że podczas pierwszego załadowania strony to pole jest puste, więc parseInt() zwróci NaN.

Żeby to naprawić, przenieś linię:

var dystans = document.getElementById("kilometry").value;

do wnętrza funkcji pokazTekst().

Wtedy wartość zmiennej dystans będzie zawsze aktualna smiley

0 głosów
odpowiedź 11 kwietnia 2022 przez VBService Ekspert (252,660 p.)
edycja 11 kwietnia 2022 przez VBService

Moim zdaniem, żeby formularz prawidłowo podawał informację o kwocie za dostawę, wartości

        var zaznaczono = document.getElementById("zaznaczono").checked;
        var dystans = document.getElementById("kilometry").value;

muszą być odczytywane po wywołaniu funkcji  pokazTekst()

 

propozycja zmian

<!DOCTYPE html>
<html lang="pl">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      body {
        font-family: Arial, Helvetica, sans-serif;
        background-color: brown;
        color: white;
      }

      div {
        text-align: center;
        font-size: 30px;
      }

      input {
        font-size: 20px;
      }

      button {
        font-size: 20px;
      }

      h1 {

      }
    </style>
  </head>
  <body>
    <div>
      <h1> PIZZERIA</h1>
      <form action="">
        <label for="kilometry">Ilość kilometrów</label>
        <input type="text" name="kilometry" id="kilometry" />

        <label for="zaznaczono">Jestem z Warszawy</label>
        <input type="checkbox" name="zaznaczono" id="zaznaczono" />

        <button onclick="pokazTekst()" type="button">Ile płacę?</button>
        <span id="tekst"></span>
      </form>
    </div>

    <script>
      const tekst = document.getElementById("tekst");

      function pokazTekst() {
        const zaznaczono = document.getElementById("zaznaczono").checked || false;
        const dystans = parseInt(document.getElementById("kilometry").value.trim()) || null;
        
        let komunikat = 'Proszę podać ilość kilometrów';
        if (zaznaczono)
          komunikat = 'Dowóz jest darmowy';
        else
          if (dystans || dystans > 0) {
            const cena = parseInt(dystans) * 2;
            komunikat = 'Dowóz będzie cię kosztował ' + cena + ' złot';
            komunikat += (['2','3','4'].includes(cena.toString().slice(-1))) ? 'e':'ych';
          }          

        tekst.innerHTML = komunikat;
      }
    </script>
  </body>
</html>

 

Podobne pytania

0 głosów
1 odpowiedź 248 wizyt
pytanie zadane 9 sierpnia 2015 w PHP przez Else Stary wyjadacz (12,260 p.)
0 głosów
1 odpowiedź 266 wizyt
0 głosów
1 odpowiedź 223 wizyt
pytanie zadane 11 października 2017 w Rozwój zawodowy, nauka, praca przez Kitsugaya Nowicjusz (200 p.)

92,535 zapytań

141,376 odpowiedzi

319,449 komentarzy

61,920 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...