jQuery ajax(複習)—Baidu ajax request分離版_javascript技巧
你沒有看錯標題,本文的確是在講Baidu ajax,不過是很久很久以前的版本了。
由於jQuery ajax模組有800 行,而核心函數jQuery.ajax就有380 行,直接分析這段程式碼很容易被程式碼邏輯弄暈。
所以我們先分析一段簡單的ajax程式碼,來自早期的百度七巧板專案。
透過這個來先複習一次ajax的知識。
baidu.ajax.request分離版
複製程式碼
複製程式碼
複製程式碼
複製碼>
/**
* 發送一個ajax請求
* @author: allstar, erik, berg
* @name ajax.request
* @function
* @grammar ajax.request(url[, options] )
* @param {string} url 傳送請求的url
* @param {Object} options 傳送請求的選項參數
* @config {String} [method] 要求傳送的類型。預設為GET
* @config {Boolean} [async] 是否非同步請求。預設為true(非同步)
* @config {String} [data] 需要傳送的資料。如果是GET請求的話,不需要這個屬性
* @config {Object} [headers] 要設定的http request header
* @config {number} [timeout] 超時時間,單位ms
* @ config {String} [username] 使用者名稱
* @config {String} [password] 密碼
* @config {Function} [onsuccess] 請求成功時觸發,function(XMLHttpRequest xhr, string responseText)。
* @config {Function} [onfailure] 請求失敗時觸發,function(XMLHttpRequest xhr)。
* @config {Function} [onbeforerequest] 發送請求之前觸發,function(XMLHttpRequest xhr)。
*
* @meta standard
* @see ajax.get,ajax.post
*
* @returns {XMLHttpRequest} 發送請求的XMLHttpRequest
物件*/
var ajax = {};
ajax.request = function(url,options,type){
// 是否需要非同步
var async = options.async||true,
// 使用者名稱、密碼
username = options.username||"",
password = options.password||"",
/ / 需要傳輸的資料
data = options.data||"",
// GET或POST
method = (options.method||"GET").toUpperCase(),
/ / 請求頭
headers = options.headers||{},
// 事件處理函數表
eventHandler = {},
// 請求資料類型
dataType = type||" string";//xml||string
function stateChangeHandler(){
// 看看是否已經準備好了
if(xhr.readyState == 4){
// 得到xhr當前狀態
var sta = xhr.status;
// 判斷是否成功
if(sta == 200||sta == 304){
// 成功則觸發成功
fire( "success");
}else{
// 失敗則觸發失敗
fire("failure");
}
// 清除綁定
window.setTimeout(function (){
xhr.onreadystatechange= new Function();
if (async){
xhr = null;
}
},0);
}
}
function fire(type){
// 把type變成ontype
type = "on" type;
// 在事件處理器表中找出對應事件的處理函數
var handler = eventHandler[type];
// 如果函數存在,則
if(handler){
// 不成功的話
if(type != "onsuccess"){
handler (xhr);
// 成功了
}else{
// 則根據dataType傳回不同的資料
handler(xhr,dataType!="xml"?xhr.responseText:xhr.responseXML );
}
}
}
// 組裝eventHandler
for(var key in options){
eventHandler[key] = options[key];
}
// 新建一個XMLHttpRequest物件
var xhr = new XMLHttpRequest();
// 如果方法是GET,則把資料組裝到url
if(method == "GET"){
url = (url.indexOf("?")>=0)?"&":"?";
url = data;
// 清空data
data = null;
}
// 如果是非同步
if (async){
// 綁定readystatechange的處理器
xhr.onreadystatechange = stateChangeHandler;
}
// 看看是否需要輸入密碼
if(username){
xhr.open(method,url,async,username,passowrd);
}else{
xhr.open(method,url,async);
}
// 如果是POST
if(method == "POST"){
// 設定一下請求頭
xhr.setRequestHeader("Content-Type", "application/x- www-form-urlencoded");
}
這段程式碼還是比較容易理解的:
•透過XMLHttpRequest()新建一個XMLHttpRequest物件。
•看看是GET,還是POST方式,如果是GET則組裝url,如果是POST,設定請求頭。
•看看是不是非同步,如果是則註冊監聽函式stateChangeHandler。
•看看需不需要使用者名稱和密碼,執行open。
•發送請求。
•等待監聽函數處理事件。
baidu.ajax.get & baidu.ajax.post
程式碼如下:
/**
* 發送一個post請求
* @name ajax.post
* @function
* @grammar ajax.post(url, data[, onsuccess])
* @param {string} url 發送請求的url位址
* @param {string} data 發送的資料
* @param {Function} [onsuccess] 請求成功之後的回呼函數,function(XMLHttpRequest xhr, string responseText)
* @meta standard
* @see ajax.get,ajax.request
*
* @returns {XMLHttpRequest} 發送請求的XMLHttpRequest物件
*/
ajax.post = function(url,data,onsuccess){
return ajax.request(url,{"data":data,"onsuccess":onsuccess,method :"POST"});
複製碼
代碼如下:
/**
* 發送一個get請求
* @name ajax.get
* @function
* @grammar ajax.get(url[, onsuccess])
* @param {string} url 傳送請求的url位址
* @param {Function} [onsuccess] 請求成功之後的回呼函數,function(XMLHttpRequest xhr, string responseText)
* @meta standard
* * @returns {XMLHttpRequest} 發送請求的XMLHttpRequest物件*/ ajax.get = function(url,data,onsuccess){ return ajax.request(url,{"data":data,"onsuccess": onsuccess}); } baidu.ajax.get和baidu.ajax.post都是透過baidu.ajax.request擴充的。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

標題:解決jQueryAJAX請求出現403錯誤的方法及程式碼範例403錯誤是指伺服器禁止存取資源的請求,通常會導致出現這個錯誤的原因是請求缺少權限或被伺服器拒絕。在進行jQueryAJAX請求時,有時會遇到這種情況,本文將介紹如何解決這個問題,並提供程式碼範例。解決方法:檢查權限:首先要確保請求的URL位址是正確的,同時驗證是否有足夠的權限來存取該資

jQuery是一個受歡迎的JavaScript函式庫,用來簡化客戶端端的開發。而AJAX則是在不重新載入整個網頁的情況下,透過發送非同步請求和與伺服器互動的技術。然而在使用jQuery進行AJAX請求時,有時會遇到403錯誤。 403錯誤通常是伺服器禁止存取的錯誤,可能是由於安全性原則或權限問題導致的。在本文中,我們將討論如何解決jQueryAJAX請求遭遇403錯誤

使用Ajax從PHP方法取得變數是Web開發中常見的場景,透過Ajax可以實作頁面無需刷新即可動態取得資料。在本文中,將介紹如何使用Ajax從PHP方法中取得變量,並提供具體的程式碼範例。首先,我們需要寫一個PHP檔案來處理Ajax請求,並傳回所需的變數。下面是一個簡單的PHP檔案getData.php的範例程式碼:

如何解決jQueryAJAX報錯403的問題?在開發網頁應用程式時,經常會使用jQuery來發送非同步請求。然而,有時在使用jQueryAJAX時可能會遇到錯誤代碼403,表示伺服器禁止存取。這種情況通常是由伺服器端的安全性設定所導致的,但可以透過一些方法來解決這個問題。本文將介紹如何解決jQueryAJAX報錯403的問題,並提供具體的程式碼範例。一、使

使用PHP和Ajax建置自動完成建議引擎:伺服器端腳本:處理Ajax請求並傳回建議(autocomplete.php)。客戶端腳本:發送Ajax請求並顯示建議(autocomplete.js)。實戰案例:在HTML頁面中包含腳本並指定search-input元素識別碼。

Ajax(非同步JavaScript和XML)允許在不重新載入頁面情況下新增動態內容。使用PHP和Ajax,您可以動態載入產品清單:HTML建立一個帶有容器元素的頁面,Ajax請求載入資料後將資料加入到該元素中。 JavaScript使用Ajax透過XMLHttpRequest向伺服器傳送請求,從伺服器取得JSON格式的產品資料。 PHP使用MySQL從資料庫查詢產品數據,並將其編碼為JSON格式。 JavaScript解析JSON數據,並將其顯示在頁面容器中。點選按鈕觸發Ajax請求,載入產品清單。

PHP中的Request物件是用來處理客戶端傳送到伺服器的HTTP請求的物件。透過Request對象,我們可以取得客戶端的請求訊息,例如請求方法、請求頭資訊、請求參數等,從而實現對請求的處理和回應。在PHP中,可以使用$_REQUEST、$_GET、$_POST等全域變數來取得要求的信息,但是這些變數並不是對象,而是陣列。為了更靈活和方便地處理請求訊息,可

為了提升Ajax安全性,有幾種方法:CSRF保護:產生令牌並將其傳送到客戶端,在請求中新增至伺服器端進行驗證。 XSS保護:使用htmlspecialchars()過濾輸入,防止惡意腳本注入。 Content-Security-Policy頭:限制惡意資源加載,指定允許載入腳本和樣式表的來源。驗證伺服器端輸入:驗證從Ajax請求接收的輸入,防止攻擊者利用輸入漏洞。使用安全Ajax函式庫:利用jQuery等函式庫提供的自動CSRF保護模組。
