gpt4 book ai didi

javascript - moment.js "invalid date"计算时间差

转载 作者:行者123 更新时间:2023-11-28 07:43:18 24 4
gpt4 key购买 nike

我正在尝试计算两个表单字段之间的时差(以小时和分钟为单位),但返回“无效日期”。我尝试使用其他示例并使它们满足我的需要。输入用于开始和结束字段。

<script type="text/javascript" src="/js/moment.js"></script>
<script type="text/javascript">
function calculate(){
var start = document.getElementById(StartTime);
var end = document.getElementById(EndTime);
var diff = moment.utc(moment(end,"HH:mm").diff(moment(start,"HH:mm"))).format("HH:mm")
document.form.total.value = diff;
}
</script>
<form method="POST" name="form" id="form" action="test2.php">
<?php
echo "time1: <input type='text' name='StartTime' id='StartTime' onChange='calculate()'/> <br />";
echo "time2: <input type='text' name='EndTime' id='EndTime' onChange='calculate()' /> <br />";
echo "difference: <input type='text' name='total' id='total' /> <br /> ";
echo "<Br />";
?>
</form>

谢谢

最佳答案

请看下面的代码:

<html>
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.8.4/moment.min.js"></script>

<script type="text/javascript">
function calculate(){
var start = document.getElementById("startTime").value;
var end = document.getElementById("endTime").value;
var formatStr = "HH:mm";
var diff = moment.utc(moment(end, formatStr).diff(moment(start, formatStr)));
document.getElementById("total").innerHTML = diff.format(formatStr);
}
</script>

<input type='text' id='startTime' onChange='calculate()'/>
<input type='text' id='endTime' onChange='calculate()' />
<div id='total' />
</html>

我删除了 php 代码,因为调试它没有用,并且该问题无关。请注意,您需要使用 .value 获取输入值。

关于javascript - moment.js "invalid date"计算时间差,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27755212/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com