Stop jquery-ui datepicker from showing in beforeShow

后端 未结 6 1962
不知归路
不知归路 2021-01-13 13:10

I wish to do something like this:

var showme = false;

$(\'#mydatepicker\').datepicker({
    beforeShow: function(input, inst) {
        if(!showme) {
               


        
相关标签:
6条回答
  • 2021-01-13 13:48

    Since this patch has not been merged in, I was able to come up with a hack that works pretty well. Let me know what you think:

    beforeShow: function(){
        var start = $('#dtFrom').val()
        if($.trim(start)!=''){
            start = $('#dtFrom').datepicker('getDate');
            $('#DateToDisplay').datepicker('option', 'minDate', new Date(start.getTime()));
        }
    },
        onClose: function() {
        var start = $('#dtFrom').val()
        if($.trim(start)==''){
            alert('Error! Please select a start date\/time prior to setting the date to display.');
            $('#DateToDisplay').val('')
        }
    }
    
    0 讨论(0)
  • 2021-01-13 14:01

    I had the same question, and have discovered that you can now use return false; to prevent the calendar from showing.

    $('#mydatepicker').datepicker({
        beforeShow: function(input, inst) {
            if(!showme) {
                return false;
            }
        }
    });
    

    I'm using version 1.7.2 of jQuery UI

    0 讨论(0)
  • 2021-01-13 14:04

    Looking through the source, it doesn't look like that is possible currently. You might be able to request that as a feature. If you really want to make it stop (though this is probably a bad idea) you could throw an error in that function. Though this will cause errors to show up for your page and probably is not an option.


    Note: I submitted a patch for this and it's now in the released jQuery UI (at least v1.9 and later), although the documentation doesn't mention it. return false in beforeShow will prevent the datepicker from appearing (now).

    0 讨论(0)
  • 2021-01-13 14:05

    The best way to prevent datepicker from opening is to use the following function in beforeShow:

    $("#datepicker").datepicker("close");

    this forces datepicker to close before it even get's shown.

    0 讨论(0)
  • 2021-01-13 14:09

    It might be better to simply control the showing of the datepicker with the disable and enable method parameters.

    $('#mydatepicker').datepicker('disable'); //Don't show datepicker 
    
    $('#mydatepicker').datepicker('enable'); //Show datepicker
    

    It would seem to accomplish the same purpose that you are seeking.

    0 讨论(0)
  • 2021-01-13 14:09

    Seems to be the closest I could get too, but I don't really want to have to use setTimeout here, it seems a bit hacky:

            var showme = false;
    
            $('#mydatepicker').datepicker({
                beforeShow: function (input, inst) {
    
                    if (!showme) {
    
                        setTimeout(function () { $(input).datepicker("hide"); }, 1);
    
                    }
                }
            });
    
    0 讨论(0)
提交回复
热议问题