我认为你是对的。
这种方法太全局了...
然而,当您的AJAX调用对页面本身没有影响时,它是一个很好的默认值。(例如后台保存)。 (您始终可以通过传递“global”:false来关闭某个ajax调用的全局设置-请参阅jquery文档)
当AJAX调用旨在刷新页面的一部分时,我喜欢我的“加载”图像特定于刷新的部分。 我想看到哪个部分被刷新。
想象一下,如果您可以简单地编写类似以下内容的内容,那将是多么酷:
$("#component_to_refresh").ajax( { ... } );
这将在此部分显示“加载”。
下面是我编写的一个处理“加载”显示的函数,但它仅适用于您在ajax中刷新的区域。
首先,让我向您展示如何使用它
<span id="email" name="name" class="ajax-loading">
</span>
$(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);
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);
};