jQuery是一種廣泛使用JavaScript庫,用于簡化在網站上的各種HTML事件操作,例如動畫、事件處理、AJAX等。jQuery中的AJAX(Asynchronous JavaScript and XML)使得前端開發人員更容易處理異步請求和響應。下面將對jQuery AJAX的一些原理進行介紹。
$.ajax({ url: "/api/getData", method: "GET", dataType: "json", data: { "term": "2021" }, success: function(response) { console.log(response); }, error: function(xhr, status, error) { console.log("An error occurred: " + error); } });
在這個示例中,我們看到了一個使用jQuery AJAX的基本結構。我們最先調用$.ajax方法,并以JavaScript對象的形式傳遞一些大寫首字母縮寫參數。參數中,url參數指定了請求的URL;method參數指定了請求的方式(GET或POST);dataType參數指定了預期的數據類型(json, xml, html等);data參數將參數打包在請求中;success函數是當服務器成功響應請求時調用的函數;error函數是當服務器無法響應請求時調用的函數。
AJAX中最重要的概念是異步。異步允許我們在等待服務器響應時同時執行其他 JavaScript 代碼,而不會使瀏覽器掛起。這是因為傳統的同步請求需要等待服務器響應后才能繼續執行后續操作。異步請求的工作原理是通過XMLHttpRequest對象(AT&T貝爾實驗室開發)進行操作。
jquery庫對XMLHttpRequest對象進行了良好的封裝,我們幾乎不需要關心請求響應的生命周期。XMLHttpRequest對象創建之后,會通過XMLHttpRequest.open()方法打開一個新的異步請求,該請求會返回一個XMLHttpRequest對象。注意,這時請求并未發送,直到我們調用XMLHttpRequest.send()方法發送請求。這個send()調用是異步的,因此我們可以在等待響應時同時處理其他任務。