dskvfdxgdo2422392 2014-09-05 08:09
浏览 19
已采纳

使用php和css在2个日期之间的进度条

i want a progressbar to show the how much time completed between 2 given days, most probably i got answer but it doesn't work on some cases

Styles:

<style type="text/css">
    #progressbar div
    {
      background-color: #99cc66;
       width: 50%; 
       height: 20px;
       border-radius: 10px;

    }
    </style>

case 1: working code

<?php
$date1 = strtotime("2014-09-05 11:44:01");
$date2 = strtotime("2014-09-07 12:44:01");
$today = time();


$num = $today - $date1;
$den = $date2 - $date1;
$percentage = ($today - $date1) / ($date2 - $date1) * 100;
?>
<?php if($percentage<100 && $percentage>=0){ ?>
<div id="progressbar" style="border: 1px solid ; border-radius: 10px;">
<div style="width: <?php echo $percentage; ?>%;"><span><?php echo round($percentage,2); ?>%</span></div>
</div>
<?php } ?>

case 2: not working

if i have to change the datetime format to 24 hours, i can't see the prgoressbar the $percentage is in negative values

<?php
$date1 = strtotime("2014-09-05 11:44:01");
$date2 = strtotime("2014-09-07 23:44:01");
$today = time();


$num = $today - $date1;
$den = $date2 - $date1;
$percentage = ($today - $date1) / ($date2 - $date1) * 100;
?>
<?php if($percentage<100 && $percentage>=0){ ?>
<div id="progressbar" style="border: 1px solid ; border-radius: 10px;">
<div style="width: <?php echo $percentage; ?>%;"><span><?php echo round($percentage,2); ?>%</span></div>
</div>
<?php } ?>

i want this progressbar work with the even 24hour format, any clue on this?

  • 写回答

3条回答 默认 最新

  • drxt70655 2014-09-05 08:21
    关注

    Just try using this logic:

    if ($today < $date1)
    {
        $perentage = 0;
    }
    else if ($today > $date2)
    {
        $percentage = 100;
    }
    else
    {
        //$date2 - $date1 = 216000 (difference between 2 days)
        // Logic
        // 216000          => 100%
        // $date2 - $today =>   x%
        // x = ($date2 - $today) / 2160
        //$percentage = ($date2 - $today) / 2160
        //As the OP mentioned the difference can vary so here's how to do it for any diff.
        $percentage = ($date2 - $today) * 100 / ($date2 - $date1);
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 angular开发过程中,想要读取模型文件,即图1的335行,会报404错误(如图2)。但我的springboot里配置了静态资源文件,如图3。且在该地址下我有模型文件如图4,请问该问题该如何解决呢?
  • ¥15 itunes恢复数据最后一步发生错误
  • ¥15 关于#windows#的问题:2024年5月15日的win11更新后资源管理器没有地址栏了顶部的地址栏和文件搜索都消失了
  • ¥100 H5网页如何调用微信扫一扫功能?
  • ¥15 讲解电路图,付费求解
  • ¥15 有偿请教计算电磁学的问题涉及到空间中时域UTD和FDTD算法结合的
  • ¥15 vite打包后,页面出现h.createElement is not a function,但本地运行正常
  • ¥15 Java,消息推送配置
  • ¥15 Java计划序号重编制功能,此功能会对所有序号重新排序,排序后不改变前后置关系。
  • ¥15 关于哈夫曼树应用得到一些问题