delaying actions between keypress in jQuery

后端 未结 5 1230
刺人心
刺人心 2020-12-08 02:23

How can I delay actions between keypress in jQuery. For example;

I have something like this

 if($(this).val().length > 1){
   $.post(\"stuff.php\"         


        
相关标签:
5条回答
  • 2020-12-08 03:04

    You can use jQuery's data abilities to do this, something like this:

    $('#mySearch').keyup(function() {
      clearTimeout($.data(this, 'timer'));
      var wait = setTimeout(search, 500);
      $(this).data('timer', wait);
    });
    
    function search() {
      $.post("stuff.php", {nStr: "" + $('#mySearch').val() + ""}, function(data){
        if(data.length > 0) {
          $('#suggestions').show();
          $('#autoSuggestionsList').html(data);
        }else{
          $('#suggestions').hide();
        }
      });
    }
    

    The main advantage here is no global variables all over the place, and you could wrap this in an anonymous function in the setTimeout if you wanted, just trying to make the example as clean as possible.

    0 讨论(0)
  • 2020-12-08 03:04

    All you need to do is wrap your function in a timeout that gets reset when the user presses a key:

    var ref;
    var myfunc = function(){
       ref = null;
       //your code goes here
    };
    var wrapper = function(){
        window.clearTimeout(ref);
        ref = window.setTimeout(myfunc, 500);
    }
    

    Then simply invoke "wrapper" in your key event.

    0 讨论(0)
  • 2020-12-08 03:10

    I'd wrap it in a function like so:

      var needsDelay = false;
    
      function getSuggestions(var search)
      {
        if(!needsDelay)
        {
            needsDelay = true;
            setTimeout("needsDelay = false", 500);
    
            if($(this).val().length > 1){
                $.post("stuff.php", {nStr: "" + search + ""}, function(data){
                    if(data.length > 0) {
                        $('#suggestions').show();
                        $('#autoSuggestionsList').html(data);
                    }else{
                        $('#suggestions').hide();
                    }
                });
            }
        }
    
    
      }
    

    That way no matter how many times you ping this, you will never search more than every 500 milliseconds.

    0 讨论(0)
  • 2020-12-08 03:17

    Nick's answer is perfect but if handling first event immediately is critical then I think we can do:

    $(selector).keyup(function(e){ //or another event
    
        if($(this).val().length > 1){
            if !($.data(this, 'bouncing-locked')) {
    
                $.data(this, 'bouncing-locked', true)
    
                $.post("stuff.php", {nStr: "" + $(this).val() + ""}, function(data){
                    if(data.length > 0) {
                        $('#suggestions').show();
                        $('#autoSuggestionsList').html(data);
                    }else{
                        $('#suggestions').hide();
                    }
               });
    
                self = this
                setTimeout(function() {
                    $.data(self, 'bouncing-locked', false);
    
                    //in case the last event matters, be sure not to miss it
                    $(this).trigger("keyup"); // call again the source event
                }, 500)
            }
        }
    });
    
    0 讨论(0)
  • 2020-12-08 03:21

    There is a nice plugin to handle this. jQuery Throttle / Debounce

    0 讨论(0)
提交回复
热议问题