2009-11-05 156 views

回答

8
$.ajax({ 
    url: '/test.xml', 
    beforeSend: function(XMLHttpRequest) { 
     // Show the div before sending the request 
     $('#load').show(); 
    }, 
    complete: function(XMLHttpRequest, textStatus) { 
     // Hide the div no matter if the call succeeded or not 
     $('#load').hide(); 
    }, 
    success: function(xml) { 
     // if the request succeeds do something with the received XML   
    } 
}); 
+0

爲什麼這是「最好的」解決方案?礦井幾乎完全相同並具有「0」。不是我在乎,而是讓我想知道這裏的「得分系統」嗎? – 2011-02-04 00:40:42

3
$.ajax({ 
    type: "GET", 
    url: "your.xml", 
    dataType: "xml", 
    beforeSend: function() { 
     $('#div').fadeIn(); 
    }, 
    success: function(xml) { 
     // example for parsing xml 
     $(xml).find('YOUR_XML_TAG').each(function(){ 
      // append xml to page HERE 
     }); 
    }, 
    complete: function() { 
     $('#div').fadeOut(); 
    } 
}); 
2

@cballou您的代碼將離開 '#div' 「起來」,如果$。阿賈克斯()尚未suceeded任何的許多可能的原因。

+0

注意和修復。 – 2009-12-02 20:08:47

0

我會在頁面URL更改時使用onbeforeunload事件來創建一個覆蓋div,其中不透明度爲0.5,當頁面加載時將被新內容替換。

1

幾乎正確;) 絕不低估刪除冗餘$()調用的重要性。所以......

//all of this is inside some closure or function 
var $blanket = $("#div") ; 
// check if after last call, something has possibly removed your '#div' 
// throw if false 
ASSERT($blanket.length === 1) ;  
$.ajax({ 
     type: "GET", 
     url: "your.xml", 
     dataType: "xml", 
     beforeSend: function() { $blanket.fadeIn(); 
     }, 
     success: function(xml) { 
      // example for parsing xml 
      $(xml).find('YOUR_XML_TAG').each(function(){ 
       // append xml to page HERE 
      }); 
     }, 
     complete: function() { $blanket.fadeOut(); 
     } 
    }); 

--DBJ

相關問題