首先我們需要清楚的是jquery load方法是對jQuery.ajax()進行封裝以方便我們使用的一個方法,當我們需要處理較為復雜的邏輯時候,還是需要用到jQuery.ajax()這個比較全面的方法的。
調用load方法的完整語法格式:load( url, [data], [callback] )
其中:url是指要導入文件的地址。
data:可選參數;因為load不僅僅可以導入靜態的html文件,還可以導入動態腳本,例如PHP文件,所以要導入的是動態文件時,我們可以把要傳遞的參數放在這裡。
callback:可選參數;是指調用load方法並得到服務器響應後,再執行的另外一個函數。
下面給出幾個用法示例:
1.加載一個php文件,該php文件不含傳遞參數
. 代碼如下:2. 加載一個php文件,該php文件含有一個傳遞參數
. 代碼如下:3. 加載一個php文件,該php文件含有多個傳遞參數。注:參數間用逗號分隔
. 代碼如下:4. 加載一個php文件,該php文件以數組作為傳遞參數
. 代碼如下:注意:使用load,這些參數是以POST的方式傳遞的,因此在/test.php裡,不能用GET來獲取參數。
5. 如何使用 callback,比如我們要在load方法得到服務器響應後,慢慢地顯示加載的內容,就可以使用callback函數。代碼如下:
. 代碼如下:6. 加載頁面片段
.load() 方法允許我們規定要插入的遠程文檔的某個部分。這一點是通過 url 參數的特殊語法實現的。如果該字符串中包含一個或多個空格,緊接第一個空格的字符串則是決定所加載內容的 jQuery 選擇器。比如:
. 代碼如下:7. 防止jquery load使用緩存的方法
緩存這東西,在一定程度上加快了頁面的裝載,但是也常常給我們帶來麻煩。在實際運用中,我們可能會碰到浏覽器緩存的問題。比如我就在IE7裡碰到這個問題。
. 代碼如下:當我更新了test.html以後,在IE7裡load方法仍舊在使用舊的test.html,就算我按刷新鍵也不管用。好在jQuery提供一個防止ajax使用緩存的方法,把下面的語句加在head的javascript文件裡,就可以解決問題。
. 代碼如下:此外我再介紹幾種方法解決緩存的方法。注意:我沒有在jQuery load的問題上測試過,這些方法僅供參考!
1.更改文件名,比如把test.html改成lables_new.html,但是這是沒有辦法的辦法,一般沒有人這麼做。
2.在test.html後加上特定時間,比如test.html?20081116。在實際工作中,在我更新css/javascript文件後,我都是用這種辦法來防止文件被緩存。
3.在test.html文件的頂部加入以下聲明:
. 代碼如下:另外在使用 jquery load 的時候需要注意的是:
(1)如果綁定給window對象,則會在所有內容加載後觸發,包括窗口,框架,對象和圖像。如果綁定在元素上,則當元素的內容加載完畢後觸發。
(2)只有當在這個元素完全加載完之前綁定load的處理函數,才會在他加載完後觸發。如果之後再綁定就永遠不會觸發了。所以不要在$(document).ready()裡綁定load事件,因為jQuery會在所有DOM加載完成後再綁定load事件。
(3)jQuery 使用浏覽器的 .innerHTML 屬性來解析被取回的文檔,並把它插入當前文檔。在此過程中,浏覽器常會從文檔中過濾掉元素,比如 <html>, <title> 或 <head> 元素。結果是,由 .load() 取回的元素可能與由浏覽器直接取回的文檔不完全相同。