jQuery - Ajax
AJAX là từ viết tắt của Asynchronous JavaScript and XML và công nghệ này giúp chúng ta tải dữ liệu từ máy chủ mà không cần làm mới trang trình duyệt.
Nếu bạn chưa quen với AJAX, tôi khuyên bạn nên xem qua Hướng dẫn Ajax của chúng tôi trước khi tiếp tục.
JQuery là một công cụ tuyệt vời cung cấp một loạt các phương pháp AJAX phong phú để phát triển ứng dụng web thế hệ tiếp theo.
Tải dữ liệu đơn giản
Điều này rất dễ dàng để tải bất kỳ dữ liệu tĩnh hoặc động nào bằng JQuery AJAX. JQuery cung cấpload() phương pháp thực hiện công việc -
Cú pháp
Đây là cú pháp đơn giản cho load() phương pháp -
[selector].load( URL, [data], [callback] );
Đây là mô tả của tất cả các tham số -
URL- URL của tài nguyên phía máy chủ mà yêu cầu được gửi đến. Nó có thể là tập lệnh CGI, ASP, JSP hoặc PHP tạo dữ liệu động hoặc từ cơ sở dữ liệu.
data- Tham số tùy chọn này đại diện cho một đối tượng có các thuộc tính được tuần tự hóa thành các tham số được mã hóa thích hợp để được chuyển đến yêu cầu. Nếu được chỉ định, yêu cầu được thực hiện bằng cách sử dụngPOSTphương pháp. Nếu bỏ qua,GET phương pháp được sử dụng.
callback- Một hàm gọi lại được gọi sau khi dữ liệu phản hồi đã được tải vào các phần tử của tập hợp đã so khớp. Tham số đầu tiên được truyền cho hàm này là văn bản phản hồi nhận được từ máy chủ và tham số thứ hai là mã trạng thái.
Thí dụ
Hãy xem xét tệp HTML sau với một đoạn mã JQuery nhỏ:
<html>
<head>
<title>The jQuery Example</title>
<script type = "text/javascript"
src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
</script>
<script type = "text/javascript" language = "javascript">
$(document).ready(function() {
$("#driver").click(function(event){
$('#stage').load('/jquery/result.html');
});
});
</script>
</head>
<body>
<p>Click on the button to load /jquery/result.html file −</p>
<div id = "stage" style = "background-color:cc0;">
STAGE
</div>
<input type = "button" id = "driver" value = "Load Data" />
</body>
</html>
Đây load() bắt đầu một yêu cầu Ajax đến URL được chỉ định /jquery/result.htmltập tin. Sau khi tải tệp này, tất cả nội dung sẽ được điền vào bên trong <div> được gắn thẻ với giai đoạn ID . Giả sử, tệp /jquery/result.html của chúng tôi chỉ có một dòng HTML -
<h1>THIS IS RESULT...</h1>
Khi bạn nhấp vào nút đã cho, thì tệp result.html sẽ được tải.
Nhận dữ liệu JSON
Sẽ có một tình huống khi máy chủ trả về chuỗi JSON so với yêu cầu của bạn. Hàm tiện ích JQuerygetJSON() phân tích cú pháp chuỗi JSON được trả về và làm cho chuỗi kết quả có sẵn cho hàm gọi lại dưới dạng tham số đầu tiên để thực hiện thêm hành động.
Cú pháp
Đây là cú pháp đơn giản cho getJSON() phương pháp -
[selector].getJSON( URL, [data], [callback] );
Đây là mô tả của tất cả các tham số -
URL - URL của tài nguyên phía máy chủ được liên hệ qua phương thức GET.
data - Đối tượng có thuộc tính đóng vai trò là cặp tên / giá trị được sử dụng để tạo chuỗi truy vấn được nối vào URL hoặc chuỗi truy vấn được mã hóa và định dạng trước.
callback- Một hàm được gọi khi yêu cầu hoàn thành. Giá trị dữ liệu thu được từ việc phân tích nội dung phản hồi dưới dạng chuỗi JSON được chuyển làm tham số đầu tiên cho lệnh gọi lại này và trạng thái là tham số thứ hai.
Thí dụ
Hãy xem xét tệp HTML sau với một đoạn mã JQuery nhỏ:
<html>
<head>
<title>The jQuery Example</title>
<script type = "text/javascript"
src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
</script>
<script type = "text/javascript" language = "javascript">
$(document).ready(function() {
$("#driver").click(function(event){
$.getJSON('/jquery/result.json', function(jd) {
$('#stage').html('<p> Name: ' + jd.name + '</p>');
$('#stage').append('<p>Age : ' + jd.age+ '</p>');
$('#stage').append('<p> Sex: ' + jd.sex+ '</p>');
});
});
});
</script>
</head>
<body>
<p>Click on the button to load result.json file −</p>
<div id = "stage" style = "background-color:#eee;">
STAGE
</div>
<input type = "button" id = "driver" value = "Load Data" />
</body>
</html>
Đây là phương thức tiện ích JQuery getJSON() bắt đầu một yêu cầu Ajax đến URL được chỉ định result.jsontập tin. Sau khi tải tệp này, tất cả nội dung sẽ được chuyển đến hàm gọi lại, cuối cùng sẽ được điền vào bên trong <div> được gắn thẻ với giai đoạn ID . Giả sử, tệp result.json của chúng ta có nội dung được định dạng json sau:
{
"name": "Zara Ali",
"age" : "67",
"sex": "female"
}
Khi bạn nhấp vào nút đã cho, thì tệp result.json sẽ được tải.
Truyền dữ liệu đến máy chủ
Nhiều khi bạn thu thập đầu vào từ người dùng và bạn chuyển đầu vào đó cho máy chủ để xử lý thêm. JQuery AJAX giúp dễ dàng chuyển dữ liệu đã thu thập đến máy chủ bằng cách sử dụngdata tham số của bất kỳ phương thức Ajax có sẵn nào.
Thí dụ
Ví dụ này chứng minh cách có thể chuyển thông tin đầu vào của người dùng tới một tập lệnh máy chủ web sẽ gửi lại cùng một kết quả và chúng tôi sẽ in nó ra -
<html>
<head>
<title>The jQuery Example</title>
<script type = "text/javascript"
src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
</script>
<script type = "text/javascript" language = "javascript">
$(document).ready(function() {
$("#driver").click(function(event){
var name = $("#name").val();
$("#stage").load('/jquery/result.php', {"name":name} );
});
});
</script>
</head>
<body>
<p>Enter your name and click on the button:</p>
<input type = "input" id = "name" size = "40" /><br />
<div id = "stage" style = "background-color:cc0;">
STAGE
</div>
<input type = "button" id = "driver" value = "Show Result" />
</body>
</html>
Đây là mã được viết bằng result.php script -
<?php
if( $_REQUEST["name"] ){
$name = $_REQUEST['name'];
echo "Welcome ". $name;
}
?>
Bây giờ bạn có thể nhập bất kỳ văn bản nào vào ô nhập liệu đã cho và sau đó nhấp vào nút "Hiển thị Kết quả" để xem những gì bạn đã nhập vào ô nhập liệu.
Các phương thức JQuery AJAX
Bạn đã thấy khái niệm cơ bản về AJAX bằng cách sử dụng JQuery. Bảng sau liệt kê tất cả các phương thức JQuery AJAX quan trọng mà bạn có thể sử dụng dựa trên nhu cầu lập trình của mình:
Sr.No. | Phương pháp & Mô tả |
---|---|
1 | jQuery.ajax (tùy chọn) Tải trang từ xa bằng yêu cầu HTTP. |
2 | jQuery.ajaxSetup (tùy chọn) Thiết lập cài đặt chung cho các yêu cầu AJAX. |
3 | jQuery.get (url, [data], [callback], [type]) Tải trang từ xa bằng yêu cầu HTTP GET. |
4 | jQuery.getJSON (url, [data], [callback]) Tải dữ liệu JSON bằng yêu cầu HTTP GET. |
5 | jQuery.getScript (url, [callback]) Tải và thực thi tệp JavaScript bằng yêu cầu HTTP GET. |
6 | jQuery.post (url, [data], [callback], [type]) Tải trang từ xa bằng yêu cầu HTTP POST. |
7 | tải (url, [dữ liệu], [gọi lại]) Tải HTML từ một tệp từ xa và đưa nó vào DOM. |
số 8 | serialize () Tuần tự hóa một tập hợp các phần tử đầu vào thành một chuỗi dữ liệu. |
9 | serializeArray () Sắp xếp thứ tự tất cả các biểu mẫu và phần tử biểu mẫu như phương thức .serialize () nhưng trả về cấu trúc dữ liệu JSON để bạn làm việc. |
Sự kiện JQuery AJAX
Bạn có thể gọi các phương thức JQuery khác nhau trong vòng đời của tiến trình gọi AJAX. Dựa trên các sự kiện / giai đoạn khác nhau, có các phương pháp sau:
Bạn có thể xem qua tất cả các Sự kiện AJAX .
Sr.No. | Phương pháp & Mô tả |
---|---|
1 | ajaxComplete (gọi lại) Đính kèm một hàm sẽ được thực thi bất cứ khi nào một yêu cầu AJAX hoàn thành. |
2 | ajaxStart (gọi lại) Đính kèm một hàm được thực thi bất cứ khi nào một yêu cầu AJAX bắt đầu và chưa có hàm nào hoạt động. |
3 | ajaxError (gọi lại) Đính kèm một hàm được thực thi bất cứ khi nào một yêu cầu AJAX không thành công. |
4 | ajaxSend (gọi lại) Đính kèm một hàm sẽ được thực thi trước khi yêu cầu AJAX được gửi đi. |
5 | ajaxStop (gọi lại) Đính kèm một hàm sẽ được thực thi bất cứ khi nào tất cả các yêu cầu AJAX đã kết thúc. |
6 | ajaxSuccess (gọi lại) Đính kèm một hàm sẽ được thực thi bất cứ khi nào một yêu cầu AJAX hoàn tất thành công. |