2017-01-09 6 views
-2

カウントダウンして自分のウェブサイトに入れたいと思っています。私はカウントダウンをしましたが、私はそれを起動すると、秒は、彼らはもうここ
は私がやったことある...実行していない、凍結され、問題を抱えている: HTML/JavaScriptの秒数をカウントダウンしてループする方法

<span id="dhour"></span> h <span id="dmin"></span> min <span id="dsec"></span> sec 
<div id="count2"></div> 
<div class="numbers" id="dday" hidden="true"></div> 
<script> 
    var montharray = new Array("Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"); 
    var year; 
    var month; 
    var day; 
    var hour = 19; 
    var minute = 10; 
    var tz = 0; 
    var ladate; 
    var today; 

    function myCallback(json) { 

     ladate = new Date(json.dateString); 

     year = ladate.getFullYear(); 
     month = ladate.getMonth() + 1; 
     day = ladate.getDate(); 
     countdown(year, month, day, hour, minute); 
    } 

    function countdown(yr, m, d, hr, min) { 
     theyear = yr; 
     themonth = m; 
     theday = d; 
     thehour = hr; 
     theminute = min; 
     today = ladate; 
     var todayy = today.getYear(); 
     if (todayy < 1000) { 
      todayy += 1900; 
     } 

     var todaym = today.getMonth(); 
     var todayd = today.getDate(); 
     var todayh = today.getHours(); 
     var todaymin = today.getMinutes(); 
     var todaysec = today.getSeconds(); 
     var todaystring1 = montharray[todaym] + " " + todayd + ", " + todayy + " " + todayh + ":" + todaymin + ":" + todaysec; 
     var todaystring = Date.parse(todaystring1) + (tz * 1000 * 60 * 60); 
     var futurestring1 = (montharray[m - 1] + " " + d + ", " + yr + " " + hr + ":" + min); 
     var futurestring = Date.parse(futurestring1) - (today.getTimezoneOffset() * (1000 * 60)); 
     var dd = futurestring - todaystring; 
     var dday = Math.floor(dd/(60 * 60 * 1000 * 24) * 1); 
     var dhour = Math.floor((dd % (60 * 60 * 1000 * 24))/(60 * 60 * 1000) * 1); 
     var dmin = Math.floor(((dd % (60 * 60 * 1000 * 24)) % (60 * 60 * 1000))/(60 * 1000) * 1); 
     var dsec = Math.floor((((dd % (60 * 60 * 1000 * 24)) % (60 * 60 * 1000)) % (60 * 1000))/1000 * 1); 

     if (dday <= 0 && dhour <= 0 && dmin <= 0 && dsec <= 0) { 
      document.getElementById('count2').style.display = "inline"; 
      document.getElementById('after').style.display = "none"; 

      document.getElementById('dday').style.display = "none"; 
      document.getElementById('dhour').style.display = "none"; 
      document.getElementById('dmin').style.display = "none"; 
      document.getElementById('dsec').style.display = "none"; 
      document.getElementById('days').style.display = "none"; 
      document.getElementById('hours').style.display = "none"; 
      document.getElementById('minutes').style.display = "none"; 
      document.getElementById('seconds').style.display = "none"; 
      return; 
     } else { 
      document.getElementById('count2').style.display = "none"; 
      document.getElementById('dday').innerHTML = dday; 
      document.getElementById('dhour').innerHTML = dhour; 
      document.getElementById('dmin').innerHTML = dmin; 
      document.getElementById('dsec').innerHTML = dsec; 
      setTimeout("countdown(theyear,themonth,theday,thehour,theminute)", 1000); 
     } 
    } 
</script> 
<script type="text/javascript" src="http://www.timeapi.org/utc/now.json?callback=myCallback"></script> 

はありがとうございます。
これを修正することを願っています。

+0

:以下は、カスタムコードを拡張することができる作業カウントダウンの簡単なコード例ですか? –

+0

上記のように、表示されたコードのどこにでも関数を呼び出すことはありません。また、この質問は 'jquery'と' php'とタグ付けされていますが、どちらもあなたの質問で使用されたり、言及されていないことに注意してください。これは、(好きな)人があなたの質問をクリックするように導くことができますが、知識があまりないかもしれません。 – Loek

+0

のjavacript – Sheva07

答えて

3

あなたが行う場合は、この:

function countdown(yr, m, d, hr, min) { 
    /**/console.log(yr, m, d, hr, min); 
} 

...あなたが同じ値を持つcountdownたびに呼び出している表示されます。あなたのコード内

何も変数のいずれかをインクリメント:意図したとおりに、あなたのコードが動作しない理由を

setTimeout("countdown(theyear,themonth,theday,thehour,theminute)", 1000); 
+0

カウントダウンはまだリアルタイムではありません – Sheva07

+0

@ Sheva07確かに、これには追加のエラーがある可能性があります。私は包括的なバグ報告をしませんでした。 –

1

answer from Álvaro Gonzálezは正しく記載していません。私はカウントダウンのための最小限の作業ソリューションから始め、コードの一部を徐々に更新し、コードが意図どおりに機能するまで、それが動作するようにテストしておくことをお勧めします。あなたが関数を呼び出している

function startCountdown(targetdate){ 
 
    var timerID = setInterval(function(){//repeat this function each 1000 ms 
 
    //get current date updated at each repetition 
 
    var now = new Date; 
 
    //compare this to the target date 
 
    var differenceInSeconds = Math.floor((targetdate - now)/1000); 
 
    //if targetdate has not yet been reached 
 
    if(differenceInSeconds > 0){ 
 
     //display how much time left 
 
     var message = differenceInSeconds + ' seconds left until ' + targetdate; 
 
    } else { 
 
     //display that countdown is over 
 
     var message = 'Targetdate has been reached' 
 
     //clear timer 
 
     clearInterval(timerID); 
 
    } 
 
    document.getElementById('showCountdown').innerHTML = message; 
 
    }, 1000); //set function to repeat every second 
 
} 
 

 
//start countdown, set to 15 seconds from the time it is started 
 
startCountdown(new Date((+new Date) + 1000 * 15));
<div id="showCountdown"></div>

関連する問題