- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是我的表格:
<input type="text" class="date" name="date[]">
<input type="text" class="starttime" name="starttime[]">
<input type="text" class="endtime" name="endtime[]">
<input type="text" class="hours" name="hours[]">
计算
starttime
之间的小时数和
endtime
我用这个js:
$('.endtime').on('change', function() {
//get values
var date = $('.date').val();
var starttime = $('.starttime').val();
var endtime = $('.endtime').val();
//create date format
var timeStart = new Date("01-01-2021 " + starttime).getHours();
var timeEnd = new Date("01-01-2021 " + endtime).getHours();
//console.log(timeStart, timeEnd);
var hourDiff = timeEnd - timeStart;
if (hourDiff < 0) {
hourDiff = 24 + hourDiff;
}
$(".hours").val(hourDiff); // output in input field
});
假设开始时间是
12:00
结束时间是
15:45
,输出应该是
3.75
但它显示给我
3
.
最佳答案
不只使用计算中的小时数。您至少也需要几分钟,但您也可以使用 Date
的完整分辨率。 (毫秒):
// Get the milliseconds-since-The-Epoch values for the times on 01/01/2021
const timeStart = Date.parse("2021-01-01T" + starttime);
const timeEnd = Date.parse("2021-01-01T" + endtime);
// Calculate the difference, divide to get a fractional hours value
let hourDiff = (timeEnd - timeStart) / 1000 / 60 / 60;
if (hourDiff < 0) {
hourDiff += 24;
}
// Format it to two decimals for display
$(".hours").val(hourDiff.toFixed(2));
(
Date.parse
的解析方式与
new Date
相同,但返回的是毫秒数,而不是日期对象。)
Year-Month-Day
和
T
而不是空格),因此字符串位于
the standard format .
function example(starttime, endtime) {
// Get the milliseconds-since-The-Epoch values for the times on 01/01/2021
const timeStart = Date.parse("2021-01-01T" + starttime);
const timeEnd = Date.parse("2021-01-01T" + endtime);
// Calculate the difference, divide to get a fractional hours value
let hourDiff = (timeEnd - timeStart) / 1000 / 60 / 60;
if (hourDiff < 0) {
hourDiff += 24;
}
// Format it to two decimals for display
console.log(starttime, "to", endtime, "=>", hourDiff.toFixed(2));
}
example("12:00", "15:45");
example("12:00", "03:45");
function toHours(time) {
const parts = time.split(":");
const hours = Number(parts[0]) || 0;
const minutes = Number(parts[1]) || 0;
const seconds = Number(parts[2]) || 0;
return hours + (minutes / 60) + (seconds / 3600);
}
然后
// Format it to two decimals for display
let hourDiff = toHours(endtime) - toHours(starttime);
if (hourDiff < 0) {
hourDiff += 24;
}
$(".hours").val(hourDiff.toFixed(2));
现场示例:
function toHours(time) {
const parts = time.split(":");
const hours = Number(parts[0]) || 0;
const minutes = Number(parts[1]) || 0;
const seconds = Number(parts[2]) || 0;
return hours + (minutes / 60) + (seconds / 3600);
}
function example(starttime, endtime) {
let hourDiff = toHours(endtime) - toHours(starttime);
if (hourDiff < 0) {
hourDiff += 24;
}
console.log(starttime, "to", endtime, "=>", hourDiff.toFixed(2));
}
example("12:00", "15:45");
example("12:00", "03:45");
example("12:00", "3:45");
Date
目的。它更直接。
if (hourDiff < 0)
检查结束时间是否真的有可能在开始时间之前,但是您在原件中有它们,所以我想我应该将它们留在那里。如果结束时间不能早于开始时间,您可以安全地删除它们。
关于javascript - 如何计算点后面两位小数的小时差,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68871944/
我正在尝试创建一个程序,该程序采用两个军事时间的差异并获取其时差。 示例: **上午到下午** 时间 1:0900 时间 2:1730 时差:8 小时 30 分钟 **下午到上午** 时间 1:120
我正在尝试计算两个时间字段之间的时间差异。由于这些字段只是没有日期的时间,因此我无法使用 timestampdiff,因此我使用 timediff() 或 subtime() 。唯一的问题是,当第二次
我试图简单地计算 5:30:00 - 2:30:00 的时差。显然这应该导致 3:00:00 但是当我在控制台中执行以下代码时 var a = new Date(0,0,0,5,30,0) var b
我试图在 C 中区分两个日期,但我收到这样的输出: future date: 18-11-2013 22:8 current date: 18-11-2013 22:8 这是我的代码: #includ
我正在尝试计算截至上午 00:00 的剩余分钟数。 DELIMITER // CREATE PROCEDURE midnightCountdown() BEGIN SELECT TIME_FORMAT
我正在尝试使用 postgresql 从表(login_history as t1)中检索以分钟为单位的时差。 当我尝试这段代码时 ((date_part('hour', timestamp '201
欢迎!我有问题想问你。我正在 Laravel 5.2 中为自己编写飞行日志。在公式中,我将有起飞时间和到达时间,但我不知道如何在 laravel 中计算时间差并将其自动传递到数据库。因此,最简单的方法
我已经查看了有关此主题的其他问答,但没有找到任何帮助。 我的应用记录比赛结果并保存到文件。 第一次点击它会写入当前时间,当运行者完成后,它会再次记录当前时间。 如何计算这两个时间以获得比赛时间? 这是
我有非常简单的代码来计算两次之间的差异: import java.text.SimpleDateFormat; import java.util.Date; import java.util.Greg
在 Python 中比较 2 次以加快测试一段代码的正确方法是什么?我尝试阅读 API 文档。我不确定我是否理解 timedelta。 到目前为止,我有这个代码: from datetime impo
这个问题非常类似于Best timestamp format for CSV/Excel? : 我正在写一个 CSV 文件。我需要编写至少精确到秒,最好精确到毫秒的时间跨度(又名时差)。 CSV 文件
我试图通过输入时间格式计算12小时内的java时差,当我输入开始时间11:58:10 pm和结束时间12:02时效果很好:15 点。但当我输入 12:00:00 am 和 12:00:00 pm 时,
因此,对于一项作业,我们必须编写一个程序,该程序需要两次军事时间,并显示它们之间的小时和分钟差异,假设第一次是两次时间中较早的一次。我们不允许使用 if 语句,因为它在技术上尚未被学习。这是运行时的示
我必须为分布在全局各地的所有人员制定 24 小时时间表。 例如,某人可以在 10:00 开始工作,并在 19:00 结束工作,因此获得时差非常简单,因为结束时间和开始时间在同一天。但是,如果我有人在
使用 ntp 时间时,(英国)返回的时间总是比实际时间少一小时。例如:现在时间是 13.35 但当我说日期时,它返回 12.35。有什么建议? try: c = ntplib.
我有一个应用程序,它在登录时记录时间,在退出时记录退出时间。 我的表有 IN_TIME 和 OUT_TIME 这些列中的数据示例: IN_TIME = 16:06:46 结束时间 = 16:08:07
我使用 $_POST 将变量从 ajax 表单发布到 php 服务器端我有两个变量,时间和金额。在服务器中,我有一个 MYSQL 数据库,其中包含 _end_time (数据类型:时间)和金额(数据类
我正在尝试计算在这里工作的人的轮类模式,从结束时间减去开始时间在大多数情况下都有效,但如果他们通宵工作则不行。例如,从 10pm 到 6am 工作的人将显示为: 22:00 - 06:00 我希望返回
任何人都可以提供一个 Excel 方程来计算两个 UTC 时间戳之间的差异。 UTC 时间戳的格式为 yyyymmddhhmmssZ(例如 20160127175049Z)。时间戳之间的差异最多为几个
我在大学学习一门名为“智能机器”的类(class)。我们向我们介绍了 3 种强化学习方法,并通过这些方法我们获得了何时使用它们的直觉,我引用: Q-Learning - 当 MDP 无法解决时最好。
我是一名优秀的程序员,十分优秀!