AJAX- databasis voorbeeld
AJAX kan gebruik word vir interaktiewe kommunikasie met 'n databasis.
AJAX-databasis voorbeeld
Die volgende voorbeeld sal demonstreer hoe 'n webblad inligting van 'n databasis met AJAX kan haal:
Voorbeeld
Customer info will be listed here...
Voorbeeld verduidelik - Die showCustomer()-funksie
Wanneer 'n gebruiker 'n kliënt in die aftreklys hierbo kies, word 'n funksie genaamd showCustomer()
uitgevoer. Die funksie word geaktiveer deur die onchange
gebeurtenis:
wys Kliënt
function showCustomer(str) {
if (str == "") {
document.getElementById("txtHint").innerHTML = "";
return;
}
const xhttp = new XMLHttpRequest();
xhttp.onload = function() {
document.getElementById("txtHint").innerHTML = this.responseText;
}
xhttp.open("GET", "getcustomer.php?q="+str);
xhttp.send();
}
Die showCustomer()
funksie doen die volgende:
- Kyk of 'n kliënt gekies is
- Skep 'n XMLHttpRequest-objek
- Skep die funksie wat uitgevoer moet word wanneer die bedienerantwoord gereed is
- Stuur die versoek na 'n lêer op die bediener
- Let daarop dat 'n parameter (q) by die URL gevoeg word (met die inhoud van die aftreklys)
Die AJAX-bedienerbladsy
Die bladsy op die bediener wat deur die JavaScript hierbo genoem word, is 'n PHP-lêer genaamd "getcustomer.php".
Die bronkode in "getcustomer.php" voer 'n navraag teen 'n databasis uit en gee die resultaat in 'n HTML-tabel terug:
<?php
$mysqli = new mysqli("servername", "username",
"password", "dbname");
if($mysqli->connect_error) {
exit('Could not connect');
}
$sql = "SELECT customerid, companyname,
contactname, address, city, postalcode, country
FROM customers WHERE
customerid = ?";
$stmt = $mysqli->prepare($sql);
$stmt->bind_param("s", $_GET['q']);
$stmt->execute();
$stmt->store_result();
$stmt->bind_result($cid,
$cname, $name, $adr, $city, $pcode, $country);
$stmt->fetch();
$stmt->close();
echo "<table>";
echo "<tr>";
echo "<th>CustomerID</th>";
echo
"<td>" . $cid . "</td>";
echo "<th>CompanyName</th>";
echo "<td>" . $cname
. "</td>";
echo "<th>ContactName</th>";
echo "<td>" . $name . "</td>";
echo "<th>Address</th>";
echo "<td>" .
$adr . "</td>";
echo "<th>City</th>";
echo "<td>" . $city . "</td>";
echo "<th>PostalCode</th>";
echo "<td>" .
$pcode . "</td>";
echo "<th>Country</th>";
echo "<td>" . $country .
"</td>";
echo "</tr>";
echo "</table>";
?>