Могу ли я отложить событие keyup для jquery? - PullRequest
11 голосов
/ 01 апреля 2012

Я использую API фильма с гнилыми томатами в сочетании с плагином twitter typeahead с использованием bootstrap 2.0.Я был в состоянии интегрировать API, но проблема у меня заключается в том, что после каждого события keyup вызывается API.Это все прекрасно, но я бы предпочел сделать вызов после небольшой паузы, позволяющей пользователю сначала ввести несколько символов.

Вот мой текущий код, который вызывает API после события keyup:

    var autocomplete = $('#searchinput').typeahead()
    .on('keyup', function(ev){

        ev.stopPropagation();
        ev.preventDefault();

        //filter out up/down, tab, enter, and escape keys
        if( $.inArray(ev.keyCode,[40,38,9,13,27]) === -1 ){

            var self = $(this);

            //set typeahead source to empty
            self.data('typeahead').source = [];

            //active used so we aren't triggering duplicate keyup events
            if( !self.data('active') && self.val().length > 0){

                self.data('active', true);

                //Do data request. Insert your own API logic here.
                $.getJSON("http://api.rottentomatoes.com/api/public/v1.0/movies.json?callback=?&apikey=MY_API_KEY&page_limit=5",{
                    q: encodeURI($(this).val())
                }, function(data) {

                    //set this to true when your callback executes
                    self.data('active',true);

                    //Filter out your own parameters. Populate them into an array, since this is what typeahead's source requires
                    var arr = [],
                        i=0;

                    var movies = data.movies;

                     $.each(movies, function(index, movie) {
                        arr[i] = movie.title
                        i++;
                     });

                    //set your results into the typehead's source 
                    self.data('typeahead').source = arr;

                    //trigger keyup on the typeahead to make it search
                    self.trigger('keyup');

                    //All done, set to false to prepare for the next remote query.
                    self.data('active', false);

                });

            }
        }
    });

Можно ли установить небольшую задержку и не вызывать API после каждого запуска?

Ответы [ 5 ]

10 голосов
/ 01 апреля 2012

это легко сделать так:

var autocomplete = $('#searchinput').typeahead().on('keyup', delayRequest);

function dataRequest() {
    // api request here
}

function delayRequest(ev) {
    if(delayRequest.timeout) {
        clearTimeout(delayRequest.timeout);
    }

    var target = this;

    delayRequest.timeout = setTimeout(function() {
        dataRequest.call(target, ev);
    }, 200); // 200ms delay
}
4 голосов
/ 01 апреля 2012

В общем, это может быть достигнуто с помощью методов setTimeout и clearTimeout:

var timer;

$('#textbox').keyup(function() {
    if (timer) {
        clearTimeout(timer);
    }
    timer = setTimeout('alert("Something cool happens here....");', 500);
});

setTimeout выполнит предоставленный JavaScript после указанного интервала в миллисекундах.clearTimeout отменит это выполнение.

Я также подготовил jsFiddle demo , показывающий фрагмент кода в действии.

Ссылки:

2 голосов
/ 30 апреля 2015

Для людей, работающих с v0.11 typeahead.js и использующими Bloodhound для получения удаленных предложений, вы можете использовать опцию rateLimitWait для регулирования запросов:

var search = new Bloodhound({
  datumTokenizer: Bloodhound.tokenizers.obj.whitespace('value'),
  queryTokenizer: Bloodhound.tokenizers.whitespace,
  remote: {
    url: '/search?q=%QUERY',
    rateLimitWait: 500
  }
});
1 голос
/ 12 декабря 2013

Не уверен, какая версия Bootstrap 2.0 использует для typeahead, но в v0.9.3 есть опция minLength, которая скрыта под капотом, но не документирована.

$('#people').typeahead({
  name: 'people',
  prefetch: './names.json',
  minLength: 3
});

Как видно из этого сообщения в блоге: http://tosbourn.com/2013/08/javascript/setting-a-minimum-length-for-your-search-in-typeahead-js/

0 голосов
/ 01 апреля 2012

Вместо задержки, если вы просто хотите разрешить пользователю вводить несколько символов перед запросом ajax $ .getJSON, вы можете изменить оператор if так, чтобы пользователь вводил, например, минимальное количество символов.3, прежде чем запрашивать данные:

if( !self.data('active') && self.val().length >=3){
...