如何从格式为“0d 0h 23m 4s”的日期中删除未使用的零?

时间:2012-03-26 06:33:38

标签: javascript date-formatting

当我说0d 0h 23m 4s ...“0d”&应删除“0h”......我该怎么做?

下面是我的代码的副本,它有效我只是不知道如何在不需要时停止显示零。例如:计时器读取.. 0d 0h 58m 3s ... 日期和时间为不需要显示所以如何做我删除它们?我希望这能让你清楚地了解这里的情况。

var year=2012    //-->Enter the count down target date YEAR
var month=3      //-->Enter the count down target date MONTH
var day=27       //-->Enter the count down target date DAY
var hour=0      //-->Enter the count down target date HOUR (24 hour clock)
var minute=00    //-->Enter the count down target date MINUTE
var tz=-5        //-->Offset for your timezone in hours from UTC (see http://wwp.greenwichmeantime.com/index.htm to find the timezone offset for your location)

//    -->DO NOT CHANGE THE CODE BELOW! This is just a personal comment dont mind it<--
var montharray=new Array("Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec")

function countdown(yr,m,d,hr,min){
theyear=yr;themonth=m;theday=d;thehour=hr;theminute=min
    var today=new Date()
    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('count').innerHTML=current;
        return;
    }
    else {
        document.getElementById('count').innerHTML=+dday+ "d "+dhour+"h "+dmin+"m "+dsec+"s";
        setTimeout("countdown(theyear,themonth,theday,thehour,theminute)",1000);
    }
}

4 个答案:

答案 0 :(得分:1)

用空字符串替换它的想法?

document.getElementById('count').innerHTML=current.replace(/0[a-z]\s/gi,'');

并且在计算时:

document.getElementById('count').innerHTML=
                 (+dday > 0 ? +dday + 'd ' : '') +
                 (dhour > 0 ? dhour+'h ' : '') +
                 (dmin > 0 ? dmin+'m ' : '') +
                  dsec+'s';

或(更短)

var val = +dday+ "d "+dhour+"h "+dmin+"m "+dsec+"s";
document.getElementById('count').innerHTML = val.replace(/0[a-z]\s/gi,'');

答案 1 :(得分:0)

试试这个

    else {
count_str = "";
if (dday > 0) {
count_str = count_str + dday + "d ";
}
if (dhour> 0) {
count_str = count_str + dhour + "h ";
}
count_str = count_str + dmin+"m "+dsec+"s"
document.getElementById('count').innerHTML=count_str;
        setTimeout("countdown(theyear,themonth,theday,thehour,theminute)",1000);
    }

答案 2 :(得分:0)

更改此行:

document.getElementById('count').innerHTML=+dday+ "d "+dhour+"h "+dmin+"m "+dsec+"s";

有条件地显示d日,dhour等。例如:

document.getElementById('count').innerHTML= ((dday !=0) ? (dday+ "d ") : "") + ((dhour !=0) ? dhour+"h " : "") +dmin+"m "+dsec+"s";

为了更清晰,您可以在多行中构建字符串,如下所示:

var counterStr = "";
if (dday != 0)
  counterStr += dday+ "d ";
if (dhour != 0)
  counterStr += dday + "h ";
counterStr += dmin+"m "+dsec+"s";

document.getElementById('count').innerHTML = counterStr;

答案 3 :(得分:-1)

不要因moment.js已经照顾过的事情而流汗。这个没有依赖关系的小javascript库负责显示日期或时间(到目前为止)。它还为本地化提供了强有力的支持。