You are not connected. Please login or register

View previous topic View next topic Go down Message [Page 1 of 1]

teenddeem
teenddeem Mới Tham Gia

Tổng số bài gửi : 5

VNĐ : 15

Uy tín : 0

Gia Nhập : 2015-07-20

Raovat368: Trung tâm đào tạo học PHP Vietpro giới thiệu tới các bạn bài học: Ajax cơ bản. Nếu bạn xác định thiết kế web thì bắt buộc bạn phải biết kỹ thuật Ajax, nó rất quan trọng cho dù bây giờ bạn chưa hiểu được tầm quan trọng của nó thì mình cũng khuyên bạn nên học nó và trong bài viết này mình sẽ giúp bạn hiểu một cách tổng quan nhất về cơ chế Ajax. Vậy nó hoạt động thế nào? Cần những hàm nào trong jQuery?

1. Ajax là gì?
Ajax là Asynchronous JavaScript and XML một nhóm công nghệ web nó giúp chúng ta load không đồng bộ trên một trang web. Ví dụ khi bạn xem một khoá học lap trinh php co ban tin tức thì sẽ thường thấy trạng thái của trình duyệt xoay xoay nhưng có cái ô comment bên dưới khi bạn bình luận thì nó hiện ra ngay, nó không tải lại toàn bộ trang mà chỉ thay đổi tại cái khu vực mà bạn thấy thôi. Đấy đại khái nó là như thế.


2. Học ajax cơ bản
Dưới đây mình sẽ hướng dẫn bạn tạo một ứng dụng ajax đơn giản là khi click vào button VIEW sau 5s thì hiển thị 1 đoạn text lên.

Đầu tiên chúng ta include thư việc jQuery, mình gọi như thế này là mặc định nó sẽ include version mới nhất về khoá học photoshop tại hà nội !


<script type="text/javascript"src=" "></script>
Sau đó thêm đoạn này vào thẻ body:


<div id="ajaxphp-results"></div>
<button id="btn">View</button>
Thẻ dev đầu tiên chúng ta để hiển thị kết quả trang php trả về, button thứ 2 là nút để bạn click

Và bây giờ đến đoạn quan trọng, bạn cho đoan script này vào bên trong thẻ head (trước thẻ body)


<script>
$(document).ready(function(){
jQuery("#btn").click(function(){
vardata_test='xin chao';
$.ajax({
url:'controller.php',
type:'POST',
data:'string='+data_test,
success:function(data){
setTimeout(function(){
$('#ajaxphp-results').html(data);
},5000);
},
error:function(e){
console.log(e.message);
}
});
});
});
</script>
Ở đây chúng ta cần đảm bảo rằng trang của chúng ta đã load hết nên chúng ta đặt code bên trong hàm này

1
$(document).ready(function(){});
Sau đó chúng ta sẽ tạo một event click chuột vào button view, vậy khi button view được click thì chúng ta sẽ xử lý cái gì?

– khai báo 1 biến có nội dung là “xin chao”

– Sử dụng hàm ajax để gửi biến ấy sang cho file php xử lý, trong hàm này cần các tham số như:

+ url: tức là nơi sẽ xử lý dữ liệu.

+ type: chính là phương thức đẩy dữ liệu đi (POST hoặc GET)

+ data: dữ liệu nào sẽ được đẩy sang, ở đây chúng ta đấy biến data_test sang và cần gán nó vào 1 tham số string để sang bên php chúng ta có thể lấy giá trị string bằng cách $_POST[‘string’] nếu type là post còn $_GET[‘string’] với type là get.

+ Hàm success sẽ thực hiện khi chúng ta thực hiện thành công, và ở đây nếu thành công chúng ta hẹn giờ 5s để nó set content cho thẻ có id là #ajaxphp-results

+ Hàm error sẽ thực hiện khi công việc thất bại. ở đây chúng ta đơn giản chỉ console.log ra thôi, cái này bạn phải học lap trinh android co ban nhấn F12 mới thấy được.

Đây là code đầy đủ trang html


<html>
<head><title>BasicAjaxDemo</title>
<script type="text/javascript"src=" "></script>
<script>
$(document).ready(function(){
jQuery("#btn").click(function(){
vardata_test='xin chao';
$.ajax({
url:'controller.php',
type:'POST',
data:'string='+data_test,
success:function(data){
setTimeout(function(){
$('#ajaxphp-results').html(data);
},5000);
},
error:function(e){
console.log(e.message);
}
});
});
});
</script>
</head>
<body>
<div id="ajaxphp-results"></div>
<button id="btn">View</button>
</body>
</html>

3. Xử lý php
Còn đây là nội dung file controller.php, file này có nhiện vụ echo nó ra nhưng ở dạng json để cho bên hàm ajax dễ xử lý.


<?php
echo json_encode($_POST['string']);
Rất đơn giản phải không ạ.
Nếu bạn chưa hiểu chỗ nào hãy comment bên dưới chúng ta cùng thảo luận về lập trình Ajax PHP

View previous topic View next topic Back to top Message [Page 1 of 1]

Permissions in this forum:
You cannot reply to topics in this forum