doubleJ
doubleJ

Reputation: 1216

Javascript Undefined Variable Before Function

I have this chunk of javascript that's kind of hacked around from http://www.developphp.com/view.php?tid=1248 and I am seeing an error of "undefined variable - broadcast".

function cdtd(broadcast) {
    /* expected date format is Month DD, YYYY HH:MM:SS */
    var nextbroadcast = new Date(broadcast);
    var now = new Date();
    var timeDiff = nextbroadcast.getTime() - now.getTime();
    if (timeDiff <= 0) {
        clearTimeout(timer);
        document.getElementById("countdown").innerHTML = "<a href=\"flconlineservices.php\">Internet broadcast in progress<\/a>";
        /* Run any code needed for countdown completion here */
    }
    var seconds = Math.floor(timeDiff / 1000);
    var minutes = Math.floor(seconds / 60);
    var hours = Math.floor(minutes / 60);
    var days = Math.floor(hours / 24);
    hours %= 24;
    minutes %= 60;
    seconds %= 60;
    document.getElementById("daysBox").innerHTML = days + " d";
    document.getElementById("hoursBox").innerHTML = hours + " h";
    document.getElementById("minsBox").innerHTML = minutes + " m";
    // seconds isn't in our html code (javascript error if this isn't commented out)
    /*document.getElementById("secsBox").innerHTML = seconds + " s";*/
    var timer = setTimeout('cdtd(broadcast)',1000);
}

"broadcast" is passed from the page with this <script type="text/javascript">cdtd("<?php echo $nextbroadcast; ?>");</script>. $nextbroadcast is based upon the date/time when the user views the page.

I tried var broadcast;, var broadcast = "";, and var broadcast = null;. Whenever I try to declare the variable, before the function, it breaks the script.

Am I doing something incorrectly? The script is working, just fine, but I'd rather not have the error.

Upvotes: 0

Views: 147

Answers (2)

Alex W
Alex W

Reputation: 38173

This might be where the problem is:

var timer = setTimeout('cdtd(broadcast)',1000);

You should declare var timer; above cdtd() function, and then set it like so below or outside of the function:

var func = 'cdtd(' + broadcast + ')';

timer = setTimeout(func,1000);

Upvotes: 2

greg84
greg84

Reputation: 7599

Change the following line:

var timer = setTimeout('cdtd(broadcast)',1000);

To this:

var timer = setTimeout(function() { cdtd(broadcast); }, 1000);

Upvotes: 2

Related Questions