如何减少给定时间

时间:2019-03-13 12:05:04

标签: javascript php

我得到的输出是00:20:00,这是正确的,但是我现在的问题是即使我减去了它,我是否仍缺少某些东西,它也不会递减?

$duration=0;
$startime=date('Y-m-d H:i:s');

$end_time=$end_time=date('Y-m-d H:i:s', 
strtotime('+'.$duration.'minutes',strtotime($startime)));

$timefirst=strtotime($startime);
$timesecond=strtotime($end_time);
$differenceinseconds=$timesecond-$timefirst;
echo gmdate("H:i:s", $differenceinseconds);

我的脚本

 <div id='response'></div>

 <script type="text/javascript">
 setInterval(function(){
    var xmlhttp=new XMLHttpRequest();
    xmlhttp.open("GET",'responseTime.php',false);
    xmlhttp.send(null);
    document.getElementById('response').innerHTML=xmlhttp.responseText;
 },1000);
     </script>

1 个答案:

答案 0 :(得分:0)

正如RiggsFolly提到的,为什么浪费服务器时间来运行计时器。 这是您可以使用JavaScript进行的操作

<div id="stopwatch"></div>
<script>
var Stopwatch = function (elem, target, options) {

var timer = createTimer(),
        offset,
        clock,
        interval;

// default options
options = options || {};
options.delay = options.delay || 1;

// append elements     
elem.appendChild(timer);

// initialize
reset();

// private functions
function createTimer() {
    var interval = 20 ; // 20 seconds
    var element = document.createElement("progress");
    element.setAttribute("max",interval);
    return element;
}

function start() {
    if (!interval) {
        offset = Date.now();
        interval = setInterval(update, options.delay);
    }
}

function stop() {
    if (interval) {
        clearInterval(interval);
        interval = null;
    }
}

function reset() {
    clock = 0;
    render();
}

function update() {
    clock += delta();
    render();
}

function render() {
    timer.value = parseInt(clock / 1000);
    if(timer.value==interval){
        // This is the point where timer ends, put your further code in here.
    }
}

function delta() {
    var now = Date.now(),
            d = now - offset;

    offset = now;
    return d;
}

// public API
this.start = start;
this.stop = stop;
this.reset = reset;
};
var elem = document.getElementById("stopwatch");
var timer = new Stopwatch(elem, {delay: 10});
timer.start();
</script>