如何显示加载旋转器在jQuery?

原型中,我可以用下面的代码显示一个“loading…”图像:

var myAjax = new Ajax.Request( url, {method: 'get', parameters: pars,
onLoading: showLoad, onComplete: showResponse} );


function showLoad () {
...
}

jQuery中,我可以这样将服务器页面加载到元素中:

$('#message').load('index.php?pg=ajaxFlashcard');

但是我如何附加一个加载旋转到这个命令,因为我在原型?

924865 次浏览

有几种方法。我更喜欢的方法是在元素本身的ajaxStart/Stop事件上附加一个函数。

$('#loadingDiv')
.hide()  // Hide it initially
.ajaxStart(function() {
$(this).show();
})
.ajaxStop(function() {
$(this).hide();
})
;

ajaxStart/Stop函数将在任何Ajax调用时触发。

更新:从jQuery 1.8开始,文档规定.ajaxStart/Stop只能附加到document。这将把上面的代码片段转换为:

var $loading = $('#loadingDiv').hide();
$(document)
.ajaxStart(function () {
$loading.show();
})
.ajaxStop(function () {
$loading.hide();
});
$('#message').load('index.php?pg=ajaxFlashcard', null, showResponse);
showLoad();


function showResponse() {
hideLoad();
...
}

http://docs.jquery.com/Ajax/load#urldatacallback

您可以在AJAX调用之前将动画图像插入到DOM中,并执行内联函数将其删除…

$("#myDiv").html('<img src="images/spinner.gif" alt="Wait" />');
$('#message').load('index.php?pg=ajaxFlashcard', null, function() {
$("#myDiv").html('');
});

这将确保你的动画在随后的请求中从相同的帧开始(如果这很重要的话)。注意,旧版本的IE 可能在动画方面有困难。

好运!

JavaScript

$.listen('click', '#captcha', function() {
$('#captcha-block').html('<div id="loading" style="width: 70px; height: 40px; display: inline-block;" />');
$.get("/captcha/new", null, function(data) {
$('#captcha-block').html(data);
});
return false;
});

CSS

#loading { background: url(/image/loading.gif) no-repeat center; }

使用加载插件:http://plugins.jquery.com/project/loading

$.loading.onAjax({img:'loading.gif'});

对于jQuery,我使用

jQuery.ajaxSetup({
beforeSend: function() {
$('#loader').show();
},
complete: function(){
$('#loader').hide();
},
success: function() {}
});

变体:我在主页的左上角有一个id="logo"的图标;当ajax工作时,一个旋转GIF被覆盖在顶部(透明)。

jQuery.ajaxSetup({
beforeSend: function() {
$('#logo').css('background', 'url(images/ajax-loader.gif) no-repeat')
},
complete: function(){
$('#logo').css('background', 'none')
},
success: function() {}
});

你可以简单地将加载器图像分配给相同的标记,稍后你将使用Ajax调用加载内容:

$("#message").html('<span>Loading...</span>');


$('#message').load('index.php?pg=ajaxFlashcard');

还可以用图像标记替换span标记。

我是这样做的:

var preloaderdiv = '<div class="thumbs_preloader">Loading...</div>';
$('#detail_thumbnails').html(preloaderdiv);
$.ajax({
async:true,
url:'./Ajaxification/getRandomUser?top='+ $(sender).css('top') +'&lef='+ $(sender).css('left'),
success:function(data){
$('#detail_thumbnails').html(data);
}
});

我使用jQuery UI对话框。(也许它也适用于其他ajax回调?)

$('<div><img src="/i/loading.gif" id="loading" /></div>').load('/ajax.html').dialog({
height: 300,
width: 600,
title: 'Wait for it...'
});

包含一个动画加载gif,直到ajax调用完成时其内容被替换为止。

我认为你是对的。 这种方法太全球化了……< / p >

然而,当AJAX调用对页面本身没有影响时,这是一个很好的默认值。(例如后台保存)。(你可以通过传递"global":false来关闭某个ajax调用-请参阅文档中的jquery

当AJAX调用是为了刷新页面的一部分时,我希望我的“加载”图像特定于刷新的部分。我想看看哪部分刷新了

想象一下,如果你可以简单地写一些像这样的东西,那该有多酷:

$("#component_to_refresh").ajax( { ... } );
这将显示该部分的“加载”。 下面是我写的一个处理“加载”显示的函数,但它是特定于你在ajax中刷新的区域。< / p >

首先,让我告诉你如何使用它

<!-- assume you have this HTML and you would like to refresh
it / load the content with ajax -->


<span id="email" name="name" class="ajax-loading">
</span>


<!-- then you have the following javascript -->


$(document).ready(function(){
$("#email").ajax({'url':"/my/url", load:true, global:false});
})

这就是它的功能——一个基本的开始,你可以随心所欲地增强它。它非常灵活。

jQuery.fn.ajax = function(options)
{
var $this = $(this);
debugger;
function invokeFunc(func, arguments)
{
if ( typeof(func) == "function")
{
func( arguments ) ;
}
}


function _think( obj, think )
{
if ( think )
{
obj.html('<div class="loading" style="background: url(/public/images/loading_1.gif) no-repeat; display:inline-block; width:70px; height:30px; padding-left:25px;"> Loading ... </div>');
}
else
{
obj.find(".loading").hide();
}
}


function makeMeThink( think )
{
if ( $this.is(".ajax-loading") )
{
_think($this,think);
}
else
{
_think($this, think);
}
}


options = $.extend({}, options); // make options not null - ridiculous, but still.
// read more about ajax events
var newoptions = $.extend({
beforeSend: function()
{
invokeFunc(options.beforeSend, null);
makeMeThink(true);
},


complete: function()
{
invokeFunc(options.complete);
makeMeThink(false);
},
success:function(result)
{
invokeFunc(options.success);
if ( options.load )
{
$this.html(result);
}
}


}, options);


$.ajax(newoptions);
};

你可以使用jQuery的.ajax函数,并使用它的选项beforeSend,并定义一些函数,在其中你可以显示加载器div和成功选项,你可以隐藏加载器div。

jQuery.ajax({
type: "POST",
url: 'YOU_URL_TO_WHICH_DATA_SEND',
data:'YOUR_DATA_TO_SEND',
beforeSend: function() {
$("#loaderDiv").show();
},
success: function(data) {
$("#loaderDiv").hide();
}
});

你可以有任何旋转Gif图像。这是一个网站,是一个伟大的AJAX加载器生成器根据你的配色方案:http://ajaxload.info/

除了为ajax事件设置全局默认值外,还可以为特定元素设置行为。也许仅仅改变他们的课程就足够了?

$('#myForm').ajaxSend( function() {
$(this).addClass('loading');
});
$('#myForm').ajaxComplete( function(){
$(this).removeClass('loading');
});

示例CSS,用旋转器隐藏#myForm:

.loading {
display: block;
background: url(spinner.gif) no-repeat center middle;
width: 124px;
height: 124px;
margin: 0 auto;
}
/* Hide all the children of the 'loading' element */
.loading * {
display: none;
}

我最终对原来的回复进行了两次更改。

  1. 从jQuery 1.8开始,ajaxStart和ajaxStop只能附加到document。这使得仅过滤某些ajax请求变得更加困难。秀……
  2. 切换到ajaxSendajaxComplete可以在显示旋转器之前检查当前ajax请求。

以下是修改后的代码:

$(document)
.hide()  // hide it initially
.ajaxSend(function(event, jqxhr, settings) {
if (settings.url !== "ajax/request.php") return;
$(".spinner").show();
})
.ajaxComplete(function(event, jqxhr, settings) {
if (settings.url !== "ajax/request.php") return;
$(".spinner").hide();
})

如果你不想自己写代码,也有很多插件可以做到这一点:

如果你正在使用$.ajax(),你可以使用像这样的东西:

$.ajax({
url: "destination url",
success: sdialog,
error: edialog,
// shows the loader element before sending.
beforeSend: function() {
$("#imgSpinner1").show();
},
// hides the loader after completion of request, whether successfull or failor.
complete: function() {
$("#imgSpinner1").hide();
},
type: 'POST',
dataType: 'json'
});

虽然该设置被命名为“beforeSend"”,但在jQuery 1.5 beforeSend"无论请求类型如何,都将被调用。中,即.show()函数将在type: 'GET'. c中被调用。

这对我来说是最好的方法:

jQuery:

$(document).ajaxStart(function() {
$(".loading").show();
});


$(document).ajaxStop(function() {
$(".loading").hide();
});

咖啡:

  $(document).ajaxStart ->
$(".loading").show()


$(document).ajaxStop ->
$(".loading").hide()

文档:ajaxStartajaxStop

我也想回答这个问题。我在jQuery中寻找类似的东西,这是我最终使用的。

我从http://ajaxload.info/中获得加载转轮。我的解决方案是基于http://christierney.com/2011/03/23/global-ajax-loading-spinners/这个简单的答案。

基本上你的HTML标记和CSS看起来是这样的:

<style>
#ajaxSpinnerImage {
display: none;
}
</style>


<div id="ajaxSpinnerContainer">
<img src="~/Content/ajax-loader.gif" id="ajaxSpinnerImage" title="working..." />
</div>

然后你为jQuery编写的代码看起来像这样:

<script>
$(document).ready(function () {
$(document)
.ajaxStart(function () {
$("#ajaxSpinnerImage").show();
})
.ajaxStop(function () {
$("#ajaxSpinnerImage").hide();
});


var owmAPI = "http://api.openweathermap.org/data/2.5/weather?q=London,uk&APPID=YourAppID";
$.getJSON(owmAPI)
.done(function (data) {
alert(data.coord.lon);
})
.fail(function () {
alert('error');
});
});
</script>

就是这么简单:)

请注意,旋转器必须使用异步调用才能工作(至少这是导致我的旋转器直到ajax调用之后才显示的原因,然后在调用结束并删除旋转器时迅速消失)。

$.ajax({
url: requestUrl,
data: data,
dataType: 'JSON',
processData: false,
type: requestMethod,
async: true,                         <<<<<<------ set async to true
accepts: 'application/json',
contentType: 'application/json',
success: function (restResponse) {
// something here
},
error: function (restResponse) {
// something here
}
});

如果您计划在每次发出服务器请求时使用加载器,则可以使用以下模式。

 jTarget.ajaxloader(); // (re)start the loader
$.post('/libs/jajaxloader/demo/service/service.php', function (content) {
jTarget.append(content); // or do something with the content
})
.always(function () {
jTarget.ajaxloader("stop");
});

这段代码特别使用了jajaxloader插件(我刚刚创建的)

https://github.com/lingtalfi/JAjaxLoader/

$('#loading-image').html('<img src="/images/ajax-loader.gif"> Sending...');


$.ajax({
url:  uri,
cache: false,
success: function(){
$('#loading-image').html('');
},


error:   function(jqXHR, textStatus, errorThrown) {
var text =  "Error has occured when submitting the job: "+jqXHR.status+ " Contact IT dept";
$('#loading-image').html('<span style="color:red">'+text +'  </span>');


}
});
这是一个非常简单和智能的插件,用于特定的目的: https://github.com/hekigan/is-loading < / p >

你总是可以使用jQuery插件为你做一切,它甚至在ajax加载时阻塞任何输入的页面。如果插件似乎没有工作,你可以阅读有关正确使用它的方法在这个回答中。检查一下。

我的ajax代码看起来是这样的,实际上,我只是注释掉了async: false行,旋转器就出现了。

$.ajax({
url: "@Url.Action("MyJsonAction", "Home")",
type: "POST",
dataType: "json",
data: {parameter:variable},
//async: false,


error: function () {
},


success: function (data) {
if (Object.keys(data).length > 0) {
//use data
}
$('#ajaxspinner').hide();
}
});

我在ajax代码之前显示了一个函数中的旋转器:

$("#MyDropDownID").change(function () {
$('#ajaxspinner').show();

对于Html,我使用了一个字体很棒的类:

<i id="ajaxspinner" class="fas fa-spinner fa-spin fa-3x fa-fw" style="display:none"></i>

希望它能帮助到别人。

<script>
$(window).on('beforeunload', function (e) {
$("#loader").show();
});
$(document).ready(function () {
$(window).load(function () {
$("#loader").hide();
});
});
</script>


<div id="loader">
<img src="../images/loader.png"
style="width:90px;">
</div>