0
У меня есть следующий код .. Но спиновый эффект не происходит, пока вызов Ajax не закончен (что в значительной степени бесполезно)Спин эффект не работает во время вызова Ajax
$.ajax({
type:"GET",
async:false,
url: "../../xxxxx/AvailabilityServlet",
data: {action: "xxx", sku: sku},
beforeSend: function(xhr) {
$("#submiticon").removeClass("fa-search");
$("#submiticon").addClass("fa-spinner fa-spin");
}
})
.done(function(data) {
result = data
})
.fail(function(data) {
result=null
})
.always(function(data) {
$("#submiticon").addClass("fa-search");
$("#submiticon").removeClass("fa-spinner");
$("#submiticon").removeClass("fa-spin");
})
Но если я добавляю предупреждает, он выдает предупреждение, а затем начинает проявляться эффект вращения.
$.ajax({
type:"GET",
async:false,
url: "../../xxxxx/AvailabilityServlet",
data: {action: "xxx", sku: sku},
beforeSend: function(xhr) {
$("#submiticon").removeClass("fa-search");
$("#submiticon").addClass("fa-spinner fa-spin");
alert("stop") ;
}
JSP:
<div class="col-md-4">
<form role="form" class="ng-pristine ng-valid">
<div class="input-group col-md-6" >
<input type="text" class="form-control" id="skuInput" placeholder="Sku" autocomplete="off" >
<span id="submit" class="input-group-addon"><span id="submiticon" class="fa fa-search"></span></span>
</div>
</form>
</div>
$("#submit").click(function(){
searchSku()
});
Спасибо .. Я просто упустил этот атрибут. Но когда я устанавливаю изменения этих элементов «до» вызова (перед отправкой) .. не предполагается ли внести эти изменения, а затем сделать вызов сервера? Извините, если это наивный вопрос. Моя экспозиция с Ajax и JQuery очень ограничена. Спасибо за помощь. – eklavya
@Vasco: он делает эти изменения перед вызовом сервера. Но пока он занят ожиданием вызова с сервера, чтобы вернуться, он не может ничего сделать, включая анимацию. –
Спасибо, Мэтт .. это дало мне больше ясности. Цените свое терпение. – eklavya