Ciao a tutti, ho un problema con un countdown scritto in javascript e che sto inserendo in un sito costruito per la maggior parte in php.
Non sapendo se il problema è su php o su javascript, ho azzardato il post in questa sezione, spero sia quella corretta....
Questo è il file .js che ho trovato in rete con le funzioni che costruiscono il countdown
codice:
function cdtime(container, targetdate)
{
if (!document.getElementById || !document.getElementById(container)) return
this.container=document.getElementById(container)
this.currentTime=new Date()
this.targetdate=new Date(targetdate)
this.timesup=false
this.updateTime()
}
cdtime.prototype.updateTime=function()
{
var thisobj=this
this.currentTime.setSeconds(this.currentTime.getSeconds()+1)
setTimeout(function(){thisobj.updateTime()}, 1000) //update time every second
}
cdtime.prototype.displaycountdown=function(baseunit, functionref)
{
this.baseunit=baseunit
this.formatresults=functionref
this.showresults()
}
cdtime.prototype.showresults=function()
{
var thisobj=this
var timediff=(this.targetdate-this.currentTime)/1000 //difference btw target date and current date, in seconds
if (timediff<0)
{ //if time is up
this.timesup=true
this.container.innerHTML=this.formatresults()
return
}
var oneMinute=60 //minute unit in seconds
var oneHour=60*60 //hour unit in seconds
var oneDay=60*60*24 //day unit in seconds
var dayfield=Math.floor(timediff/oneDay)
var hourfield=Math.floor((timediff-dayfield*oneDay)/oneHour)
var minutefield=Math.floor((timediff-dayfield*oneDay-hourfield*oneHour)/oneMinute)
var secondfield=Math.floor((timediff-dayfield*oneDay-hourfield*oneHour-minutefield*oneMinute))
if (this.baseunit=="ore")
{ //if base unit is hours, set "hourfield" to be topmost level
hourfield=dayfield*24+hourfield
dayfield="n/a"
}
else if (this.baseunit=="minuti")
{ //if base unit is minutes, set "minutefield" to be topmost level
minutefield=dayfield*24*60+hourfield*60+minutefield
dayfield=hourfield="n/a"
}
else if (this.baseunit=="secondi")
{ //if base unit is seconds, set "secondfield" to be topmost level
var secondfield=timediff
dayfield=hourfield=minutefield="n/a"
}
this.container.innerHTML=this.formatresults(dayfield, hourfield, minutefield, secondfield)
setTimeout(function(){thisobj.showresults()}, 1000) //update results every second
}
/////CUSTOM FORMAT OUTPUT FUNCTIONS BELOW//////////////////////////////
//Create your own custom format function to pass into cdtime.displaycountdown()
//Use arguments[0] to access "Days" left
//Use arguments[1] to access "Hours" left
//Use arguments[2] to access "Minutes" left
//Use arguments[3] to access "Seconds" left
//The values of these arguments may change depending on the "baseunit" parameter of cdtime.displaycountdown()
//For example, if "baseunit" is set to "hours", arguments[0] becomes meaningless and contains "n/a"
//For example, if "baseunit" is set to "minutes", arguments[0] and arguments[1] become meaningless etc
function formatresults()
{
if (this.timesup==false)
{
var displaystring="<span class='lcdstyle'><sup>Desiderio attivo ancora per</sup>
"+arguments[0]+" <sup>giorni</sup> "+arguments[1]+" <sup>ore</sup> "+arguments[2]+" <sup>minuti</sup> "+arguments[3]+" <sup>secondi</sup></span>"
}
else
{
var displaystring="<span class='lcdstyle'>Iscrizioni chiuse!</span>"
}
return displaystring
}
e questa è la porzione di codice php dove richiamo lo script, è tutto all'inteno di un ciclo while
Codice PHP:
echo '<div id="countdowncontainer" align="center" style="margin-bottom:20px"></div>';
echo '<script type="text/javascript">';
echo 'var futuredate=new cdtime("countdowncontainer", "December 2, 2011 16:52:00")';
echo 'futuredate.displaycountdown("giorni",formatresults)';
echo '</script>';
Il risultato è che mi visualizza il countdown solo sul primo record invece che su tutti.
P.S. Altra domanda....non essendo una cima in js come faccio a modificare il formato attuale del parametro della data? Vorrei semplicemente passare yyyy-mm-dd (formato memorizzato nel db)
Grazie mille.
Tony