2016-12-06 2 views
1

У меня возникли проблемы с добавлением счетчика в форму поиска при отправке формы. Спусковой механизм в конечном итоге появляется, но только до тех пор, пока функция не завершится.Добавить spinner для ввода на jquery submit

Я попытался воспроизвести ошибку, разбив ее на более мелкие части, но безрезультатно. Вот пример кода. Любые указатели будут оценены.

<form id="search" class="form-inline"> 
    <div class="input-group align-bottom" id="address_search"> 
     <input type="text" name="query" id="query" placeholder="search" class="form-control">  
     <span class="input-group-btn"> 
      <button class="btn btn-primary" type="submit"> 
       <i id="search-button" class="fa fa-search" aria-hidden="true"></i> 
      </button> 
     </span> 
    </div> 
</form> 
$("#search").submit(function() { 
    event.preventDefault(); 

    search = $("#search-button") 
    search.removeClass("fa-search") 
    search.addClass("fa-spinner fa-spin") 

    // Do Something 
    for (var i = 0; i < 50000; i++){ 
     console.log(i) 
    } 

    // Put Search icon back 
    search.removeClass("fa-search") 
    search.addClass("fa-spinner fa-pulse") 
}) 

ответ

1

Проблема в том, что петля for синхронно и блокирует поток пользовательского интерфейса от обновления с классом добавления/удаления вы сделали.

Решение это поместить петлю в setTimeout() на короткую задержку, как это:

$("#search").submit(function(e) { 
    e.preventDefault(); 

    var $search = $("#search-button") 
    $search.removeClass("fa-search").addClass("fa-spinner fa-spin") 

    setTimeout(function() { 
     for (var i = 0; i < 50000; i++){ 
      console.log(i) 
     } 

     $search.addClass("fa-search").removeClass("fa-spinner fa-spin") 
    }, 50); 
}) 

Working example

Обратите внимание, что вы должны использовать параметр event передается в обработчик события, а не глобальный объект event. Кроме того, логика находилась в обратном направлении после цикла и задавала неправильные классы, где вы заявляете, что хотите повторно установить класс fa-search.

+0

Спасибо за отзыв Рори. Я предположил, что это связано с синхронностью вызова, но я поместил счетчик в тайм-аут, рядом, но не с сигарой. – macintoshPrime

0

Если вы используете Ajax вы могли бы использовать что-то вроде следующего:

var $spinner = $('#searchButton').hide(); 
$(document) 
.ajaxStart(function() { 
    $spinner.show(); 
}) 
.ajaxStop(function() { 
    $spinner.hide(); 
}); 

ajaxStart и ajaxStop огонь на ваш звонок Ajax. Подробнее о JQuery ajaxStart и ajaxStop найдено здесь, если интересно.

Смежные вопросы