gpt4 book ai didi

jquery datepicker + 日期差异计算

转载 作者:行者123 更新时间:2023-11-30 23:47:59 24 4
gpt4 key购买 nike

这是我的代码:

$(function() {
$( "#arr_date" ).datepicker({ dateFormat: 'dd-mm-yy' });
$( "#dep_date" ).datepicker({ dateFormat: 'dd-mm-yy' });
});

$(function() {
var start = $('#arr_date').val();
var end = $('#dep_date').val();
var diff = new Date(end - start);
var days = diff/1000/60/60/24;
$('#num_nights').val(days);
});

我在 stackoverflow 上找到了这个日期差异解决方案,但它对我不起作用。

它根本不计算日期差异。我认为这可能是因为日期格式(dd-mm-yy)。我也尝试过使用 yyyy-mm-dd 格式,但它也不起作用。

有人可以帮助我并告诉我可能导致问题的原因吗?谢谢。

最佳答案

您不想使用.val()在这里,这将为您提供一个字符串,并且将字符串彼此相减并不是很有用。日期选择器有一个方法,getDate ,它为您提供了一个 Date 对象,以便您可以使用它:

var start = $('#arr_date').datepicker('getDate');
var end = $('#dep_date').datepicker('getDate');
var days = (end - start)/1000/60/60/24;

演示:http://jsfiddle.net/ambiguous/TCXcX/

另外,这段代码:

$(function() {
var start = $('#arr_date').val();
var end = $('#dep_date').val();
var diff = new Date(end - start);
var days = diff/1000/60/60/24;
$('#num_nights').val(days);
});

将在 DOM 准备就绪时运行,但您不希望它在选择日期之前运行。您需要将(更正后的)计算代码绑定(bind)到按钮或观察 onSelect 事件:

function showDays() {
var start = $('#arr_date').datepicker('getDate');
var end = $('#dep_date').datepicker('getDate');
if(!start || !end)
return;
var days = (end - start)/1000/60/60/24;
$('#num_nights').val(days);
}

$( "#arr_date" ).datepicker({ dateFormat: 'dd-mm-yy', onSelect: showDays });
$( "#dep_date" ).datepicker({ dateFormat: 'dd-mm-yy', onSelect: showDays });

另一个演示:http://jsfiddle.net/ambiguous/5BbGS/

关于jquery datepicker + 日期差异计算,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8455383/

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