Php 从持续时间计算div宽度的百分比

Php 从持续时间计算div宽度的百分比,php,html,math,calculator,Php,Html,Math,Calculator,我试图根据时间持续时间百分比计算div宽度 我有三个div,根据两个日期之间的持续时间为它们提供宽度和填充背景色 lengthdiv1=2018-4-01 22:31:59 - 2018-01-01 00:00:00 lengthdiv2=2018-10-10 22:31:59 - 2018-4-01 22:31:59 lengthdiv3=2018-12-31 23:59:59 - 2018-10-10 22:31:59 $maxWidth = 100; // total percenta

我试图根据时间持续时间百分比计算div宽度

我有三个div,根据两个日期之间的持续时间为它们提供宽度和填充背景色

lengthdiv1=2018-4-01 22:31:59 - 2018-01-01 00:00:00
lengthdiv2=2018-10-10 22:31:59 - 2018-4-01 22:31:59
lengthdiv3=2018-12-31 23:59:59 - 2018-10-10 22:31:59

 $maxWidth = 100; // total percentage 
$eventStart = strtotime('2018-01-01 00:00:00');
$eventEnd   = strtotime('2018-4-01 22:31:59');
$eventLength = $eventEnd - $eventStart;
$maxLength = 86400;
$ratio = $eventLength / $maxLength; 
$width = round($ratio * $maxWidth);
我试图以百分比形式应用div宽度的HTML代码

 <div class="daylight">
    <div class="daytime standard" style="width: 20%; background: #D1F1AD;border-left: none;">3m 23d h4</div>
    <div class="daytime summer" style="width: 60%; background: #FDE492; text-align: center">3m 23d h4</div>
    <div class="daytime standard1" style=" background: #D1F1AD;width: 20%; ">3m 23d h4</div>
  </div>

3m 23d h4
3m 23d h4
3m 23d h4

这应该是必要的

<?php
    $dur1 = (strtotime("2018-04-01 22:31:59")) - (strtotime("2018-01-01 00:00:00"));
    $dur2 = (strtotime("2018-10-10 22:31:59")) - (strtotime("2018-4-01 22:31:59"));
    $dur3 = (strtotime("2018-12-31 23:59:59")) - (strtotime("2018-10-10 22:31:59"));

    $totDur = $dur1 + $dur2 + $dur3;

    $wid1 = round($dur1 * 100 / $totDur);
    $wid2 = round($dur2 * 100 / $totDur);
    $wid3 = round($dur3 * 100 / $totDur);

    echo $wid1, " ", $wid2, " ", $wid3;

当我舍入最接近的宽度值时,某个时间可能是宽度从100%增加,并且div布局中断。如果是这种情况,您可以替换
$wid3=round($dur3*100/$totDur)具有
$wid3=100-($wid1+$wid2)。它将始终确保总宽度不超过100。是的,有一个精确性的问题,但由于这是为了观看的目的,我不认为这是需要考虑的事情。