用jQuery簡化Ajax開發(fā)實現方法第1/2頁
更新時間:2010年04月05日 23:39:03 作者:
使用 jQuery 將使 Ajax 變得及其簡單。jQuery 提供有一些函數,可以使簡單的工作變得更加簡單,復雜的工作變得不再復雜。
一些簡單的代碼簡化
下面是一個簡單示例,它說明了 jQuery 對代碼的影響。要執(zhí)行一些真正簡單和常見的任務,比方說為頁面的某一區(qū)域中的每個鏈接附加一個單擊(click)事件,您可以使用純 JavaScript 代碼和 DOM 腳本來實現,如 清單 1 所示。
清單 1 :沒有使用 jQuery 的 DOM 腳本
var external_links = document.getElementById('external_links');
var links = external_links.getElementsByTagName('a');
for (var i=0;i < links.length;i++) {
var link = links.item(i);
link.onclick = function() {
return confirm('You are going to visit: ' + this.href);
};
}
清單 2 顯示了使用 jQuery 實現的相同的功能。
清單 2. 使用了 jQuery 的 DOM 腳本
$('#external_links a').click(function() {
return confirm('You are going to visit: ' + this.href);
});
是不是很神奇? 使用 jQuery,您可以把握問題的要點,只讓代碼實現您想要的功能,而省去了一些繁瑣的過程。無需對元素進行循環(huán),click() 函數將完成這些操作。同樣也不需要進行多個 DOM 腳本調用。您只需要使用一個簡短的字符串對所需的元素進行定義即可。
理解這一代碼的工作原理可能會有一點復雜。首先,我們使用了 $() 函數 —— jQuery 中功能最強大的函數。通常,我們都是使用這個函數從文檔中選擇元素。在本例中,一個包含有一些層疊樣式表(Cascading Style Sheet,CSS)語法的字符串被傳遞給函數,然后 jQuery 盡可能高效地把這些元素找出來。
如果您具備 CSS 選擇器的基本知識,那么應該很熟悉這些語法。在 清單 2 中,#external_links 用于檢索 id 為 external_links 的元素。a 后的空格表示 jQuery 需要檢索 external_links 元素中的所有 <a> 元素。用英語說起來非常繞口,甚至在 DOM 腳本中也是這樣,但是在 CSS 中這再簡單不過了
$() 函數返回一個含有所有與 CSS 選擇器匹配的元素的 jQuery 對象。jQuery 對象 類似于數組,但是它附帶有大量特殊的 jQuery 函數。比方說,您可以通過調用 click 函數把 click 處理函數指定給 jQuery 對象中的所有元素。
還可以向 $() 函數傳遞一個元素或者一個元素數組,該函數將把這些元素封裝在一個 jQuery 對象中。您可能會想要使用這個功能將 jQuery 函數用于一些對象,比方說 window 對象。例如,我們通常會像下面這樣把函數分配給加載事件:
window.onload = function() {
// do this stuff when the page is done loading
};
使用 jQuery 編寫的功能相同的代碼:
$(window).load(function() {
// run this when the whole page has been downloaded
});
您可能有所體會,等待窗口加載的過程是非常緩慢而且令人痛苦的,這是因為必須等整個頁面加載完所有的內容,包括頁面上所有的的圖片。有的時候,您希望首先完成圖片加載,但是在大多數情況下,您只需加載超文本標志語言(Hypertext Markup Language,HTML)就可以了。通過在文檔中創(chuàng)建特殊的 ready 事件,jQuery 解決了這個問題,方法如下:
$(document).ready(function() {
// do this stuff when the HTML is all ready
});
這個代碼圍繞 document 元素創(chuàng)建了一個 jQuery 對象,然后建立一個函數,用于在 HTML DOM 文檔就緒的時候調用實例??梢愿鶕枰我獾卣{用這個函數。并且能夠以真正的 jQuery 格式,使用快捷方式調用這個函數。這很簡單,只需向 $() 函數傳遞一個函數就可以了:
$(function() {
// run this when the HTML is done downloading
});
到目前以止,我已經向大家介紹了 $() 函數的三種用法。第四種方法可以使用字符串來創(chuàng)建元素。結果會產生一個包含該元素的 jQuery 對象。清單 3 顯示的示例在頁面中添加了一個段落。
清單 3. 創(chuàng)建和附加一個簡單的段落
$('<p></p>')
.html('Hey World!')
.css('background', 'yellow')
.appendTo("body");
在前一個例子中您可能已經注意到,jQuery 中的另一個功能強大的特性就是方法鏈接(method chaining)。每次對 jQuery 對象調用方法時,方法都會返回相同的 jQuery 對象。這意味著如果您需要對 jQuery 對象調用多個方法,那么您不必重新鍵入選擇器就可以實現這一目的:使 Ajax 變得簡單
$('#message').css('background', 'yellow').html('Hello!').show();
使用 jQuery 將使 Ajax 變得及其簡單。jQuery 提供有一些函數,可以使簡單的工作變得更加簡單,復雜的工作變得不再復雜。
Ajax 最常見的用法就是把一塊 HTML 代碼加載到頁面的某個區(qū)域中去。為此,只需簡單地選擇所需的元素,然后使用 load() 函數即可。下面是一個用于更新統(tǒng)計信息的示例:
$('#stats').load('stats.html');
通常,我們只需簡單地把一些參數傳遞給服務器中的某個頁面。正如您所預料的,使用 jQuery 實現這一操作非常地簡單。您可以使用 $.post() 或者 $.get(),這由所需的方法決定。如果需要的話,您還可以傳遞一個可選的數據對象和回調函數。清單 4 顯示了一個發(fā)送數據和使用回調的簡單示例。
清單 4. 使用 Ajax 向頁面發(fā)送數據
$.post('save.cgi', {
text: 'my string',
number: 23
}, function() {
alert('Your data has been saved.');
});
如果您確實需要編寫一些復雜的 Ajax 腳本,那么需要用到 $.ajax() 函數。您可以指定 xml、script、html 或者 json,jQuery 將自動為回調函數準備合適的結果,這樣您便可以立即使用該結果。還可以指定 beforeSend、error、success 或者 complete 回調函數,向用戶提供更多有關 Ajax 體驗的反饋。此外,還有一些其它的參數可供使用,您可以使用它們設置 Ajax 請求的超時,也可以設置頁面 “最近一次修改” 的狀態(tài)。清單 5 顯示了一個使用一些我所提到的參數檢索 XML 文檔的示例。
清單 5. $.ajax() 使 Ajax 由復雜變簡單
$.ajax({
url: 'document.xml',
type: 'GET',
dataType: 'xml',
timeout: 1000,
error: function(){
alert('Error loading XML document');
},
success: function(xml){
// do something with xml
}
});
當 success 回調函數返回 XML 文檔后,您可以使用 jQuery 檢索這個 XML 文檔,其方式與檢索 HTML 文檔是一樣的。這樣使得處理 XML 文檔變得相當地容易,并且把內容和數據集成到了您的 Web 站點里面。清單 6 顯示了 success 函數的一個擴展,它為 XML 中的每個 <item> 元素都添加了一個列表項到 Web 頁面中。
清單 6. 使用 jQuery 處理 XML 文檔
success: function(xml){
$(xml).find('item').each(function(){
var item_text = $(this).text();
$('<li></li>')
.html(item_text)
.appendTo('ol');
});
}
下面是一個簡單示例,它說明了 jQuery 對代碼的影響。要執(zhí)行一些真正簡單和常見的任務,比方說為頁面的某一區(qū)域中的每個鏈接附加一個單擊(click)事件,您可以使用純 JavaScript 代碼和 DOM 腳本來實現,如 清單 1 所示。
清單 1 :沒有使用 jQuery 的 DOM 腳本
復制代碼 代碼如下:
var external_links = document.getElementById('external_links');
var links = external_links.getElementsByTagName('a');
for (var i=0;i < links.length;i++) {
var link = links.item(i);
link.onclick = function() {
return confirm('You are going to visit: ' + this.href);
};
}
清單 2 顯示了使用 jQuery 實現的相同的功能。
清單 2. 使用了 jQuery 的 DOM 腳本
復制代碼 代碼如下:
$('#external_links a').click(function() {
return confirm('You are going to visit: ' + this.href);
});
是不是很神奇? 使用 jQuery,您可以把握問題的要點,只讓代碼實現您想要的功能,而省去了一些繁瑣的過程。無需對元素進行循環(huán),click() 函數將完成這些操作。同樣也不需要進行多個 DOM 腳本調用。您只需要使用一個簡短的字符串對所需的元素進行定義即可。
理解這一代碼的工作原理可能會有一點復雜。首先,我們使用了 $() 函數 —— jQuery 中功能最強大的函數。通常,我們都是使用這個函數從文檔中選擇元素。在本例中,一個包含有一些層疊樣式表(Cascading Style Sheet,CSS)語法的字符串被傳遞給函數,然后 jQuery 盡可能高效地把這些元素找出來。
如果您具備 CSS 選擇器的基本知識,那么應該很熟悉這些語法。在 清單 2 中,#external_links 用于檢索 id 為 external_links 的元素。a 后的空格表示 jQuery 需要檢索 external_links 元素中的所有 <a> 元素。用英語說起來非常繞口,甚至在 DOM 腳本中也是這樣,但是在 CSS 中這再簡單不過了
$() 函數返回一個含有所有與 CSS 選擇器匹配的元素的 jQuery 對象。jQuery 對象 類似于數組,但是它附帶有大量特殊的 jQuery 函數。比方說,您可以通過調用 click 函數把 click 處理函數指定給 jQuery 對象中的所有元素。
還可以向 $() 函數傳遞一個元素或者一個元素數組,該函數將把這些元素封裝在一個 jQuery 對象中。您可能會想要使用這個功能將 jQuery 函數用于一些對象,比方說 window 對象。例如,我們通常會像下面這樣把函數分配給加載事件:
復制代碼 代碼如下:
window.onload = function() {
// do this stuff when the page is done loading
};
使用 jQuery 編寫的功能相同的代碼:
復制代碼 代碼如下:
$(window).load(function() {
// run this when the whole page has been downloaded
});
您可能有所體會,等待窗口加載的過程是非常緩慢而且令人痛苦的,這是因為必須等整個頁面加載完所有的內容,包括頁面上所有的的圖片。有的時候,您希望首先完成圖片加載,但是在大多數情況下,您只需加載超文本標志語言(Hypertext Markup Language,HTML)就可以了。通過在文檔中創(chuàng)建特殊的 ready 事件,jQuery 解決了這個問題,方法如下:
復制代碼 代碼如下:
$(document).ready(function() {
// do this stuff when the HTML is all ready
});
這個代碼圍繞 document 元素創(chuàng)建了一個 jQuery 對象,然后建立一個函數,用于在 HTML DOM 文檔就緒的時候調用實例??梢愿鶕枰我獾卣{用這個函數。并且能夠以真正的 jQuery 格式,使用快捷方式調用這個函數。這很簡單,只需向 $() 函數傳遞一個函數就可以了:
復制代碼 代碼如下:
$(function() {
// run this when the HTML is done downloading
});
到目前以止,我已經向大家介紹了 $() 函數的三種用法。第四種方法可以使用字符串來創(chuàng)建元素。結果會產生一個包含該元素的 jQuery 對象。清單 3 顯示的示例在頁面中添加了一個段落。
清單 3. 創(chuàng)建和附加一個簡單的段落
復制代碼 代碼如下:
$('<p></p>')
.html('Hey World!')
.css('background', 'yellow')
.appendTo("body");
在前一個例子中您可能已經注意到,jQuery 中的另一個功能強大的特性就是方法鏈接(method chaining)。每次對 jQuery 對象調用方法時,方法都會返回相同的 jQuery 對象。這意味著如果您需要對 jQuery 對象調用多個方法,那么您不必重新鍵入選擇器就可以實現這一目的:使 Ajax 變得簡單
復制代碼 代碼如下:
$('#message').css('background', 'yellow').html('Hello!').show();
使用 jQuery 將使 Ajax 變得及其簡單。jQuery 提供有一些函數,可以使簡單的工作變得更加簡單,復雜的工作變得不再復雜。
Ajax 最常見的用法就是把一塊 HTML 代碼加載到頁面的某個區(qū)域中去。為此,只需簡單地選擇所需的元素,然后使用 load() 函數即可。下面是一個用于更新統(tǒng)計信息的示例:
復制代碼 代碼如下:
$('#stats').load('stats.html');
通常,我們只需簡單地把一些參數傳遞給服務器中的某個頁面。正如您所預料的,使用 jQuery 實現這一操作非常地簡單。您可以使用 $.post() 或者 $.get(),這由所需的方法決定。如果需要的話,您還可以傳遞一個可選的數據對象和回調函數。清單 4 顯示了一個發(fā)送數據和使用回調的簡單示例。
清單 4. 使用 Ajax 向頁面發(fā)送數據
復制代碼 代碼如下:
$.post('save.cgi', {
text: 'my string',
number: 23
}, function() {
alert('Your data has been saved.');
});
如果您確實需要編寫一些復雜的 Ajax 腳本,那么需要用到 $.ajax() 函數。您可以指定 xml、script、html 或者 json,jQuery 將自動為回調函數準備合適的結果,這樣您便可以立即使用該結果。還可以指定 beforeSend、error、success 或者 complete 回調函數,向用戶提供更多有關 Ajax 體驗的反饋。此外,還有一些其它的參數可供使用,您可以使用它們設置 Ajax 請求的超時,也可以設置頁面 “最近一次修改” 的狀態(tài)。清單 5 顯示了一個使用一些我所提到的參數檢索 XML 文檔的示例。
清單 5. $.ajax() 使 Ajax 由復雜變簡單
復制代碼 代碼如下:
$.ajax({
url: 'document.xml',
type: 'GET',
dataType: 'xml',
timeout: 1000,
error: function(){
alert('Error loading XML document');
},
success: function(xml){
// do something with xml
}
});
當 success 回調函數返回 XML 文檔后,您可以使用 jQuery 檢索這個 XML 文檔,其方式與檢索 HTML 文檔是一樣的。這樣使得處理 XML 文檔變得相當地容易,并且把內容和數據集成到了您的 Web 站點里面。清單 6 顯示了 success 函數的一個擴展,它為 XML 中的每個 <item> 元素都添加了一個列表項到 Web 頁面中。
清單 6. 使用 jQuery 處理 XML 文檔
復制代碼 代碼如下:
success: function(xml){
$(xml).find('item').each(function(){
var item_text = $(this).text();
$('<li></li>')
.html(item_text)
.appendTo('ol');
});
}
相關文章
深入分析jQuery的ready函數是如何工作的(工作原理)
這篇文章主要介紹了jQuery的ready函數是如何工作的,深入分析了jQueryready函數的運作流程及相應的工作原理,需要的朋友可以參考下2015-12-12