Drukowana wersja tematu

Kliknij tu, aby zobaczyć temat w orginalnym formacie

Forum PHP.pl _ Przedszkole _ [JavaScript]Dzielenie stringa i zapis do zmiennej

Napisany przez: Sklep102 24.05.2020, 13:55:04

Cześć,
Może mi ktoś wyjaśnić w jaki sposób można podzielić tekst i zapisać do zmiennej? mam coś takiego:



  1.  
  2. var czas = document.getElementById("test").value;
  3. var podziel = czas.http://www.php.net/split(":");
  4. for(var i = 0; i < podziel.length; i++){
  5. var godziny = podziel[i];
  6. var minuty = podziel[i];
  7. var sekundy = podziel[i];
  8. alert(podziel[i]);
  9. }

i nie wiem w jaki sposób przypisać to do zmiennych, alert wyświetla się poprawnie.

Napisany przez: viking 24.05.2020, 14:08:14

  1. var godzina, minuta, sekunda;
  2. var czas = '22:05:12';
  3. [godzina, minuta, sekunda] = czas.split(':');
  4. console.log(godzina, minuta, sekunda);


https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Destructuring_assignment

Napisany przez: Sklep102 30.05.2020, 17:55:07

Cześć,
Dzięki za pomoc viking, mam pytanie odnośnie jeszcze fokusu na element a dokładnie chodzi o to że po zmianie w polu input pobiera wartość i przelicza na sekundy. Mam tylko problem ponieważ po załadowaniu strony nie działa ten skrypt jeśli kliknę raz jeszcze i zmienię to wszystko zaczyna działać. Pytanie dlaczego dopiero po kliknięciu 2 raz w input i zmianie dopiero działa a nie za pierwszym razem? co powinienem zmienić?


  1. <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
  2.  
  3. <script language="javascript">
  4.  
  5.  
  6. function gettim(){
  7. $("#test").bind("propertychange change keyup paste input", function(){
  8.  
  9. var hours, minutes, seconds;
  10. var czas = document.getElementById("test").value;
  11. [hours, minutes, seconds] = czas.http://www.php.net/split(':');
  12. console.log (hours, minutes, seconds);
  13.  
  14. var cm;
  15. cm = hours * (60 * 60) + minutes * 60 + seconds * 1;
  16. console.log (cm);
  17.  
  18. if(isNaN(cm)){
  19. cm = "00:00:05"
  20. }
  21.  
  22. var cos = $("input[name='time']");
  23. cos.val(cm);
  24.  
  25.  
  26. });
  27. }
  28.  
  29.  
  30.  
  31. </script>
  32.  
  33. <form name="frm">
  34. <input type="time" name="short_time" id="test" step="1" value="00:00:00" http://www.php.net/max="05:00:00" style="border-radius: 25px; width:35%; text-align:center" onblur="gettim()">
  35. <input onClick="time;" name="time" type="hidden" value=""/>
  36.  
  37. <input onClick="gettim();" type="button" value="Calculate" name="button" />
  38.  
  39. </form>

Napisany przez: viking 30.05.2020, 18:23:37

Po pierwsze bind jest dawno przestarzałe. Powinieneś stosowac on(). Po drugie DOM nie jest załadowany a już coś do niego przypinasz. https://api.jquery.com/ready/

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