如何在jQuery中显示加载微调器?

Edw*_*uay 401 jquery language-interoperability spinner equivalence prototypejs

Prototype中,我可以使用以下代码显示"loading ..."图像:

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

function showLoad () {
    ...
}
Run Code Online (Sandbox Code Playgroud)

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

$('#message').load('index.php?pg=ajaxFlashcard');
Run Code Online (Sandbox Code Playgroud)

但是如何像在Prototype中那样将加载微调器附加到此命令?

nic*_*ckf 780

有几种方法.我首选的方法是将一个函数附加到元素本身的ajaxStart/Stop事件上.

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

无论何时进行任何Ajax调用,都会触发ajaxStart/Stop函数.

更新:从jQuery 1.8开始,文档说明.ajaxStart/Stop应该只附加到document.这会将上面的代码段转换为:

var $loading = $('#loadingDiv').hide();
$(document)
  .ajaxStart(function () {
    $loading.show();
  })
  .ajaxStop(function () {
    $loading.hide();
  });
Run Code Online (Sandbox Code Playgroud)

  • 太全球了吗?你想要多少个"请稍候"的消息? (354认同)
  • 对于一个简单的DIV加载来说,这可能太全局了. (47认同)
  • 这种方式很遗憾,你不能控制加载div定位,以防你不想只显示一个模态加载窗口,但显示它在元素附近等待加载ajax内容... (22认同)
  • ajaxStart和ajaxStop是jQuery事件,因此您可以命名它们:http://stackoverflow.com/questions/1191485/how-to-call-ajaxstart-on-specific-ajax-calls/1212728#1212728 http://docs.jquery .COM/Namespaced_Events (9认同)
  • 如果使用jQuery> = 1.9,请将ajaxStart和ajaxStop事件附加到$(document).http://jquery.com/upgrade-guide/1.9/#ajax-events-should-be-attached-to-document (9认同)
  • 这很清楚,+1!@glaz666 - 这不是真的。*全部*关于*你*如何配置它。例如:`.ajaxStart(function(e) { CallFunctionWithTargettedElement(e.currentTarget); })` 将调用一个函数,其中参数是发起 ajax 调用的元素。请注意,这只是一个示例,不处理是否从脚本调用 ajax,而没有事件处理程序或任何其他错误检查。这只是为了表明存在控制定位的方法。被调用的函数可以在调用元素上放置一个绝对元素。 (2认同)
  • @deckoff 它仅在 ajax 请求启动并且没有 ajax 请求仍处于活动状态时触发。 (2认同)

kr0*_*lix 204

对于我使用的jQuery

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

  • 对我来说,html应该有类似的东西:<div id ='loader'> <img rel="nofollow noreferrer" src ="spinner.gif"/> </ div> (12认同)
  • 这个对我来说最干净.而不是ajaxSetup,我放置了beforeSend:并完成:在$ ajax({...语句. (6认同)
  • 不知道它的价值,但是jQuery在其文档中提到不建议使用_.ajaxSetup()_.[链接](http://api.jquery.com/jQuery.ajaxSetup/) (3认同)

See*_*ker 43

您可以使用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();
    }
});
Run Code Online (Sandbox Code Playgroud)

你可以拥有任何Spinning Gif图像.根据您的配色方案,这是一个很棒的AJAX Loader Generator网站:http://ajaxload.info/

  • 根据[jQuery Ajax Events](http://docs.jquery.com),如果出现错误,将不会调用`success`,但"即使对于同步请求,也总会收到`complete`回调"./Ajax_Events). (13认同)

Jos*_*ola 22

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

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

这将确保您的动画在后续请求的同一帧开始(如果这很重要).请注意,旧版本的IE 可能会遇到动画问题.

祝好运!

  • 顶端提示:在div中预加载spinner.gif,显示设置为none.否则,当微调器仍然下载时,您可能会得到一些延迟的微调器效果. (12认同)
  • @BothFM因为人们喜欢等待的事情......? (4认同)

Bre*_*ent 20

$('#message').load('index.php?pg=ajaxFlashcard', null, showResponse);
showLoad();

function showResponse() {
    hideLoad();
    ...
}
Run Code Online (Sandbox Code Playgroud)

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

  • @UltimateBrent 我认为你弄错了。为什么 showLoad() 不是回调?JavaScript 将异步加载内容。如果我是正确的,showLoad() 甚至在内容加载之前就可以工作。 (2认同)
  • @Jaseem 我也使用类似的方法,它实际上依赖于异步调用。我会将 showLoad 放在 ajax 调用之前的某个地方,但重点是显示一个微调器,让 JS 开始调用,并在 AJAX 完成后在回调中终止微调器。 (2认同)

Ami*_*aqi 15

如果你正在使用$.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'
    });  
Run Code Online (Sandbox Code Playgroud)


Nat*_*bna 10

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

$.loading.onAjax({img:'loading.gif'});
Run Code Online (Sandbox Code Playgroud)

  • 什么是"好"的插件?99?48?7? (10认同)
  • 这个简单任务的一个插件?这不是一个真正的好解决方案吗?谁想在页面上加载100个脚本? (9认同)
  • 不同意:单独和模块化,重用代码,如果您希望能够维护您的工作并让其他人也这样做.您的用户连接不良的可能性是什么,他们的客户端无法加载插件以及您的代码? (8认同)
  • 同意。如果您想要更好的性能,请进行压缩和连接。 (2认同)

Pau*_*aul 8

变体:我在主页的左上角有一个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() {}
});
Run Code Online (Sandbox Code Playgroud)


Emi*_*röm 8

我最后对原始回复进行了两处更改.

  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();
    })
Run Code Online (Sandbox Code Playgroud)


小智 7

您可以简单地将加载程序映像分配给稍后将使用Ajax调用加载内容的同一标记:

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

$('#message').load('index.php?pg=ajaxFlashcard');
Run Code Online (Sandbox Code Playgroud)

您还可以使用图像标记替换span标记.


Bre*_*ogt 7

我也想为这个答案做出贡献.我在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>
Run Code Online (Sandbox Code Playgroud)

然后你的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>
Run Code Online (Sandbox Code Playgroud)

它是如此简单 :)


Lee*_*Gee 6

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

$('#myForm').ajaxSend( function() {
    $(this).addClass('loading');
});
$('#myForm').ajaxComplete( function(){
    $(this).removeClass('loading');
});
Run Code Online (Sandbox Code Playgroud)

CSS示例,用spinner隐藏#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;  
}
Run Code Online (Sandbox Code Playgroud)

  • `.loading&gt; * {display:none; }`非常感谢 (2认同)