Tải bản đầy đủ (.pdf) (6 trang)

PHP và AJAX php and ajax

Bạn đang xem bản rút gọn của tài liệu. Xem và tải ngay bản đầy đủ của tài liệu tại đây (331.03 KB, 6 trang )

/>
Copyright © vietjack.com

PHP & AJAX
AJAX là gì?


AJAX là viết tắt của Asynchronous JavaScript and XML. AJAX là một kỹ thuật mới để tạo
các ứng dụng web tốt hơn, nhanh hơn, và có tính tương tác hơn với sự giúp đỡ của XML,
HTML, CSS và JavaScript.



Ứng dụng web theo qui ước truyền tải thông tin tới và từ Server bởi sử dụng các request
mang tính đồng bộ. Nghĩa là, bạn điền một form, nhấn nút Submit, và được hướng tới một
trang mới với thông tin mới từ Server đó.



Với AJAX, khi nút Submit được nhấn, JavaScript sẽ tạo một request tới Server, thông dịch
kết quả và cập nhật màn hình hiện tại. Người dùng sẽ không bao giờ biết những gì được
truyền tải tới Server.

Ví dụ về PHP và AJAX
Để minh họa rõ ràng rằng nó là dễ dàng để truy cập thông tin từ một Database bởi sử dụng AJAX
và PHP, chúng tôi xây dựng các truy vấn MySQL và hiển thị kết quả trên “ajax.html”. Nhưng trước
khi tiến hành, chúng ta cần thực hiện các công việc cơ sở. Tạo một Table bởi sử dụng lệnh sau.
CREATE TABLE `ajax_example` (
`name` varchar(50) NOT NULL,
`age` int(11) NOT NULL,
`sex` varchar(1) NOT NULL,


`wpm` int(11) NOT NULL,
PRIMARY KEY

(`name`)

)

Bây giờ, truyền dữ liệu sau vào trong Table này bởi sử dụng các lệnh SQL sau:
INSERT INTO `ajax_example` VALUES ('Jerry', 120, 'm', 20);
INSERT INTO `ajax_example` VALUES ('Regis', 75, 'm', 44);
INSERT INTO `ajax_example` VALUES ('Frank', 45, 'm', 87);
INSERT INTO `ajax_example` VALUES ('Jill', 22, 'f', 72);
INSERT INTO `ajax_example` VALUES ('Tracy', 27, 'f', 0);
INSERT INTO `ajax_example` VALUES ('Julie', 35, 'f', 90);

Trang chia sẻ các bài học online miễn phí

Page 1


/>
Copyright © vietjack.com

HTML file trên Client side
Bây giờ chúng ta có HTML file trên Client side là ajax.html và nó sẽ có code sau:
<html>
<body>

<script language="javascript" type="text/javascript">

function ajaxFunction(){
var ajaxRequest;

// The variable that makes Ajax possible!

try{
// Opera 8.0+, Firefox, Safari
ajaxRequest = new XMLHttpRequest();
}

catch (e){
// Internet Explorer Browsers
try{
ajaxRequest = new ActiveXObject("Msxml2.XMLHTTP");
}

catch (e) {
try{
ajaxRequest = new ActiveXObject("Microsoft.XMLHTTP");
}

catch (e){
// Something went wrong
alert("Your browser broke!");
return false;
}
}

Trang chia sẻ các bài học online miễn phí


Page 2


/>
Copyright © vietjack.com

}

// Create a function that will receive data
// sent from the server and will update
// div section in the same page.

ajaxRequest.onreadystatechange = function(){
if(ajaxRequest.readyState == 4){
var ajaxDisplay = document.getElementById('ajaxDiv');
ajaxDisplay.innerHTML = ajaxRequest.responseText;
}
}

// Now get the value from user and pass it to
// server script.

var age = document.getElementById('age').value;
var wpm = document.getElementById('wpm').value;
var sex = document.getElementById('sex').value;
var queryString = "?age=" + age ;

queryString +=

"&wpm=" + wpm + "&sex=" + sex;


ajaxRequest.open("GET", "ajax-example.php" + queryString, true);
ajaxRequest.send(null);
}
//-->
</script>

<form name='myForm'>
Max Age: <input type='text' id='age' />

Max WPM: <input type='text' id='wpm' />



Trang chia sẻ các bài học online miễn phí

Page 3


/>
Copyright © vietjack.com

Sex: <select id='sex'>
<option value="m">m</option>
<option value="f">f</option>
</select>

<input type='button' onclick='ajaxFunction()' value='Query MySQL'/>

</form>


<div id='ajaxDiv'>Your result will display here</div>
</body>
</html>

Ghi chú − Cách truyền các biến trong Query là tuân theo chuẩn HTTP và có form sau.
URL?variable1=value1;&variable2=value2;

Bây giờ code trên sẽ cung cấp cho bạn một màn hình như dưới đây. (Đây là màn hình minh họa và
nó sẽ không làm việc)
Max Age:

Max WPM:
Sex:
Your result will display here

PHP file trên Server side
Lúc này, script trên Client side đã sẵn sàng. Giờ chúng ta phải viết script trên Server side, mà sẽ
lấy age, wpm và sex từ Database và sẽ gửi nó trở lại tới Client. Đặt dòng code sau vào trong “ajaxexample.php” file.

$dbhost = "localhost";
$dbuser = "dbusername";
$dbpass = "dbpassword";

Trang chia sẻ các bài học online miễn phí

Page 4



/>
Copyright © vietjack.com

$dbname = "dbname";

//Connect to MySQL Server
mysql_connect($dbhost, $dbuser, $dbpass);

//Select Database
mysql_select_db($dbname) or die(mysql_error());

// Retrieve data from Query String
$age = $_GET['age'];
$sex = $_GET['sex'];
$wpm = $_GET['wpm'];

// Escape User Input to help prevent SQL Injection
$age = mysql_real_escape_string($age);
$sex = mysql_real_escape_string($sex);
$wpm = mysql_real_escape_string($wpm);

//build query
$query = "SELECT * FROM ajax_example WHERE sex = '$sex'";

if(is_numeric($age))
$query .= " AND age <= $age";

if(is_numeric($wpm))
$query .= " AND wpm <= $wpm";


//Execute query
$qry_result = mysql_query($query) or die(mysql_error());

//Build Result String
$display_string = "<table>";
$display_string .= "<tr>";

Trang chia sẻ các bài học online miễn phí

Page 5


/>
Copyright © vietjack.com

$display_string .= "<th>Name</th>";
$display_string .= "<th>Age</th>";
$display_string .= "<th>Sex</th>";
$display_string .= "<th>WPM</th>";
$display_string .= "</tr>";

// Insert a new row in the table for each person returned
while($row = mysql_fetch_array($qry_result)){
$display_string .= "<tr>";
$display_string .= "<td>$row[name]</td>";
$display_string .= "<td>$row[age]</td>";
$display_string .= "<td>$row[sex]</td>";
$display_string .= "<td>$row[wpm]</td>";
$display_string .= "</tr>";
}

echo "Query: " . $query . "
";

$display_string .= "</table>";
echo $display_string;
?>

Bây giờ, bạn thử nhập một giá trị hợp lệ trong “Max Age” hoặc bất kỳ box khác, và sau đó nhấn nút
Query MySQL.
Max Age:

Max WPM:
Sex:
Your result will display here
Nếu bạn đã hiểu chương này, thì bạn đã biết cách sử dụng MySQL, PHP, HTML, và JavaScript để
viết các ứng dụng AJAX.

Trang chia sẻ các bài học online miễn phí

Page 6



Tài liệu bạn tìm kiếm đã sẵn sàng tải về

Tải bản đầy đủ ngay
×