我的页面中有一个使用datetimepicker控件的开始时间的input框,还有一个使用datetimepicker控件的结束时间的input框,我如何点击第二个的时候自动计算并且赋值给工时这个input框呢?页面如何触发,js代码如何写
时间: 2024-02-24 15:54:35 浏览: 70
您可以使用jQuery在页面中添加事件监听器来实现这一功能。以下是具体的步骤:
1. 在页面中引入jQuery库。您可以将以下代码添加到页面的head标签中:
```html
<head>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
</head>
```
2. 在页面中添加三个DateTimePicker控件和一个input控件。第一个DateTimePicker控件用于选择开始时间,第二个DateTimePicker控件用于选择结束时间,第三个input控件用于显示工时。
3. 在页面中添加以下JavaScript代码:
```javascript
$(document).ready(function() {
// 获取开始时间和结束时间控件
var startTimePicker = $('#start-time-picker');
var endTimePicker = $('#end-time-picker');
// 获取工时输入框
var hoursInput = $('#hours-input');
// 在结束时间控件上添加change事件监听器
endTimePicker.change(function() {
// 获取开始时间和结束时间
var startTime = startTimePicker.val();
var endTime = endTimePicker.val();
// 计算时间差
var timeSpan = moment(endTime).diff(moment(startTime));
// 计算工时
var totalHours = moment.duration(timeSpan).asHours();
// 将工时赋值给工时输入框
hoursInput.val(totalHours);
});
});
```
4. 运行您的应用程序并测试。选择开始时间和结束时间后,工时输入框应该会自动显示两个时间之间的时间差。
请注意,这需要引入moment.js库,您可以在页面中直接引入该库,或者将moment.js下载到本地并引入。同时,还要注意日期和时间的格式匹配,以及异常情况的处理,例如结束时间早于开始时间的情况。
阅读全文