ฉันคิดว่าคุณถูก. วิธีนี้เป็นสากลมากเกินไป ...
อย่างไรก็ตาม - มันเป็นค่าเริ่มต้นที่ดีเมื่อการโทร AJAX ของคุณไม่มีผลกระทบกับหน้า (บันทึกพื้นหลังเป็นตัวอย่าง) (คุณสามารถปิดการโทร ajax ได้ตลอดเวลาโดยผ่าน "global": false - ดูเอกสารที่jquery
เมื่อมีการโทร AJAX เพื่อรีเฟรชบางส่วนของหน้าฉันชอบภาพ "กำลังโหลด" ของฉันที่เฉพาะเจาะจงกับส่วนที่รีเฟรช ฉันต้องการดูว่าส่วนใดรีเฟรช
ลองนึกภาพว่าเท่ห์มากแค่ไหนถ้าคุณสามารถเขียนสิ่งที่ชอบ:
$("#component_to_refresh").ajax( { ... } );
และนี่จะแสดง "กำลังโหลด" ในส่วนนี้ ด้านล่างเป็นฟังก์ชั่นที่ผมเขียนที่จัดการกับการแสดง "กำลังโหลด" เช่นกัน แต่มันก็เฉพาะกับพื้นที่ที่คุณกำลังรีเฟรชในอาแจ็กซ์
ก่อนอื่นให้ฉันแสดงวิธีใช้
<!-- 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);
};