在jQuery Timepicker中设置最长时间

时间:2014-07-30 08:58:52

标签: javascript jquery timepicker jquery-ui-timepicker

以下是我的时间选择器的当前JQuery。 如果从#from字段中选择时间,则会将#to的最长时间设置为所选时间。

如果我从#from选择了凌晨1点,#to上可以接听的最长时间是凌晨1点。

var osmaxtime = '20';
$('#from').timepicker({ 'minTime': '9','maxTime': '8','scrollDefaultNow': true,'step': 60 });
$('#from').on('changeTime', function() {
    var sFrom=$(this).val();
    $('#to').timepicker({ 'minTime': '9','maxTime':sFrom,'scrollDefaultNow': true,'step': 60 });
});
$('#to').timepicker({ 'minTime': '9','maxTime': osmaxtime,'scrollDefaultNow': true,'step': 60 });

现在我想根据#to字段增加#from字段的最长时间。

例如,如果我从#from凌晨1点起,#to的最长时间是早上4点(+4小时)

$('#from').on('changeTime', function() {
        var sFrom=$(this).val();
        var sFromPuls=sFrom+4;// Here is the problem because the value of sFrom is in String or something else.
        $('#to').timepicker({ 'minTime': '9','maxTime':sFrom,'scrollDefaultNow': true,'step': 60 });
    });

3 个答案:

答案 0 :(得分:1)

使用Number包围var以使jQuery将其识别为要向其添加4的数字

$('#from').on('changeTime', function() {
  var sFrom=$(this).val();
  var sFromPuls=Number(sFrom)+4; // Surround with Number()
  $('#to').timepicker({ 'minTime': '9',
  'maxTime':sFromPuls, //write correct var name 
  'scrollDefaultNow': true,
  'step': 60 });
});

答案 1 :(得分:0)

您可以参考onSelect documentation并在时间戳

上使用它
$('#example').datetimepicker({
    onSelect: function(){
              //Here you can add 4 hours to the start time
        }
});

答案 2 :(得分:0)

我的问题通过以下代码解决 -

$('#from').timepicker({ 'minTime': 8,'maxTime': 20,'scrollDefaultNow': true,'step': 60 });
    $('#from').on('change', function() {
        var fromTime=$(this).val();
        var hrs = Number(fromTime.match(/^(\d+)/)[1]);
        var format = fromTime.match(/00(.*)$/)[1];
        if (format == "pm" && hrs < 12) hrs = hrs + 12;
        if (format == "am" && hrs == 12) hrs = hrs - 12;
        var hours = (hrs+4).toString();         
        var sFromPuls= (parseInt(osSeletecdTime)+4).toString();
        $('#to').timepicker({ 'minTime': fromTime,'maxTime':hours ,'scrollDefaultNow': true,'step': 60 });
    });