Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [JavaScript]Countdown timer, Modyfikacja kodu
jagon
post 5.10.2010, 23:16:45
Post #1





Grupa: Zarejestrowani
Postów: 80
Pomógł: 0
Dołączył: 20.10.2007

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


Witam Was, tym razem pytanie, a raczej prośba z dziedziny Javascript

Proszę o informację w jaki sposób zmodyfikować kod (countdown timer) tak, aby po zakonczeniu odliczania, timer znikał, a na jego miejsce pojawiał się np przycisk.

Kod
var sec = 10;   // set the seconds
var min = 00;   // set the minutes

function countDown() {
  sec--;
  if (sec == -01) {
    sec = 59;
    min = min - 1;
  } else {
   min = min;
  }
  
if (sec<=9) { sec = "0" + sec; }
  time = (min<=9 ? "<b>0" + min : min) + "</b>min<b> " + sec + "</b>sec";
if (document.getElementById) { theTime.innerHTML = time; }
  SD=window.setTimeout("countDown();", 1000);
if (min == '00' && sec == '00')
{ sec = "00"; window.clearTimeout(SD); alert("hi alex");}
}

function addLoadEvent(func) {
  var oldonload = window.onload;
  if (typeof window.onload != 'function') {
    window.onload = func;
  } else {
    window.onload = function() {
      if (oldonload) {
        oldonload();
      }
      func();
    }
  }
}

addLoadEvent(function() {
  countDown();
}
);
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 6)
CuteOne
post 5.10.2010, 23:37:03
Post #2





Grupa: Zarejestrowani
Postów: 2 958
Pomógł: 574
Dołączył: 23.09.2008
Skąd: wiesz, że tu jestem?

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


Najprostszym rozwiązaniem jest chyba zmiana styli czyli po odliczeniu czasu element (np. <div>)w którym trzymasz zegar zmienia display na display = "none" a element z przyciskiem (wcześniej ustawiony jako display="none") zmienia styl na display=""

Go to the top of the page
+Quote Post
jagon
post 5.10.2010, 23:55:53
Post #3





Grupa: Zarejestrowani
Postów: 80
Pomógł: 0
Dołączył: 20.10.2007

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


Ok, więc w jaki sposób to wykonać najprościej?
Go to the top of the page
+Quote Post
CuteOne
post 6.10.2010, 02:49:16
Post #4





Grupa: Zarejestrowani
Postów: 2 958
Pomógł: 574
Dołączył: 23.09.2008
Skąd: wiesz, że tu jestem?

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


Zobacz jak to działa link, link i przerób pod swój skrypt
Go to the top of the page
+Quote Post
jagon
post 6.10.2010, 14:04:52
Post #5





Grupa: Zarejestrowani
Postów: 80
Pomógł: 0
Dołączył: 20.10.2007

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


Niestety z racji tego, że z javascript nie miałem w ogóle styczności, w dalszym ciągu sobie nie radzę.
Go to the top of the page
+Quote Post
kamil4u
post 6.10.2010, 16:38:46
Post #6





Grupa: Zarejestrowani
Postów: 2 350
Pomógł: 512
Dołączył: 4.01.2009
Skąd: Wrocław / Świdnica

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


Hmmm... jest to dość proste. Jak widzisz w kodzie masz:
Kod
if (min == '00' && sec == '00')
{ sec = "00"; window.clearTimeout(SD); alert("hi alex");}
}
, który jest wywoływany po zakończenia odliczania. Tak więc, trzeba tam dać odpowiednią funkcję. Masz 2 sensowne wyjścia to co podał poprzednik, czyli zamianę stylów display lub usunięcie elementu i stworzenia nowego zamiast tego usuniętego. Pierwszy sposób jest prostszy, dlatego go opiszę.
Potrzebujesz do tego:
- DOM -> http://kurs.browsehappy.pl/Definicja/DOM i http://kurs.browsehappy.pl/JavaScript/DOM
- zmiany stylów -> https://developer.mozilla.org/pl/DOM/element.style
i teraz pseudo kod(w miejsce tego alert-a lub przy nim):
Kod
referencja_do_licznika.style.display = 'none'; //referencje uzyskujesz dzięki DOM
referencja_do_przycisku.style.display = 'block'; //referencje uzyskujesz dzięki DOM

PS. Twój kod jest mocno średni....
PS2. Jak Ci coś nie wyjdzie to pokaż kod.


--------------------
Go to the top of the page
+Quote Post
jagon
post 7.10.2010, 14:54:16
Post #7





Grupa: Zarejestrowani
Postów: 80
Pomógł: 0
Dołączył: 20.10.2007

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


Rozwiązałem sprawę, znajdując skrypt odliczający minutę, następnie wyświetlający napis. Przerobiłem go do swoich potrzeb, dodając odliczanie minut, oraz zmieniając text na button. Gdyby się komuś przydało, to bardzo proszę:

Kod
<script type="text/javascript">
      
      var num = 59;
      var num2 = 1;
      var timer;
      var timer2;

      function countdown2(){
         if(num2 > -1){
            num2--;
            if(!timer2)
               timer2 = setInterval("countdown2()",1000*60);
         }
      }
      countdown2();

      function countdown(){
         if(num < 1 && num2 < 1){
            if(timer)
               clearTimeout(timer);
            document.getElementById('countdown_ele').innerHTML = "Gotowe!<br><input type='button' name='dload' value='Pobierz plik'>";
         }else{
            document.getElementById('countdown_ele').innerHTML = "Proszę czekać<br><font style=\'color:blue\'><b><h3 style='display:inline'>"+ num2 + "</b></h3>min, <b><h3 style='display:inline'>" + num + "</h3></b>sec</font>";
            num--;
            if(num == -1)
            {num = 59;}            
            if(!timer)
               timer = setInterval("countdown()",1000);
         }
      }
      countdown();
      
    </script>


I wyświetlanie w html:

Kod
<span id="countdown_ele"></span>


Ten post edytował jagon 7.10.2010, 16:22:22
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 14.08.2025 - 07:48