AJAX - Eylem
Bu bölüm, AJAX işleminin tam adımlarının net bir resmini verir.
AJAX İşleminin Adımları
- Bir müşteri olayı meydana gelir.
- Bir XMLHttpRequest nesnesi oluşturulur.
- XMLHttpRequest nesnesi yapılandırılır.
- XMLHttpRequest nesnesi, Web sunucusuna zaman uyumsuz bir istekte bulunur.
- Web sunucusu, XML belgesini içeren sonucu döndürür.
- XMLHttpRequest nesnesi callback () işlevini çağırır ve sonucu işler.
- HTML DOM güncellenir.
Gelin bu adımları tek tek atalım.
Bir İstemci Olayı Oluşur
Bir olayın sonucu olarak bir JavaScript işlevi çağrılır.
Örnek - validateUserId () JavaScript işlevi, kimliği "userid" olarak ayarlanmış giriş formu alanındaki bir onkeyup olayına bir olay işleyicisi olarak eşlenir
<input type = "text" size = "20" id = "userid" name = "id" onkeyup = "validateUserId ();">.
XMLHttpRequest Nesnesi Oluşturuldu
var ajaxRequest; // The variable that makes Ajax possible!
function ajaxFunction() {
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;
}
}
}
}
XMLHttpRequest Nesnesi Yapılandırıldı
Bu adımda, istemci olayı tarafından tetiklenecek bir fonksiyon yazacağız ve bir geri çağırma fonksiyonu processRequest () kaydedilecektir.
function validateUserId() {
ajaxFunction();
// Here processRequest() is the callback function.
ajaxRequest.onreadystatechange = processRequest;
if (!target) target = document.getElementById("userid");
var url = "validate?id=" + escape(target.value);
ajaxRequest.open("GET", url, true);
ajaxRequest.send(null);
}
Web sunucusuna Eşzamansız İstek Yapma
Kaynak kodu, yukarıdaki kod parçasında mevcuttur. Kalın yazı tipiyle yazılan kod, web sunucusuna bir istekte bulunmaktan sorumludur. Tüm bunlar XMLHttpRequest nesnesi ajaxRequest kullanılarak yapılıyor .
function validateUserId() {
ajaxFunction();
// Here processRequest() is the callback function.
ajaxRequest.onreadystatechange = processRequest;
if (!target) target = document.getElementById("userid"); var url = "validate?id = " + escape(target.value); ajaxRequest.open("GET", url, true); ajaxRequest.send(null);
}
Kullanıcı kimliği kutusuna Zara yazdığınızı varsayın, ardından yukarıdaki istekte URL "validate? İd = Zara" olarak ayarlanır.
Web sunucusu XML Belgesi İçeren Sonucu Döndürür
Sunucu tarafı komut dosyanızı herhangi bir dilde uygulayabilirsiniz, ancak mantığı aşağıdaki gibi olmalıdır.
- Müşteriden bir istek alın.
- İstemciden gelen girdiyi ayrıştırın.
- Gerekli işlemi yapın.
- Çıktıyı istemciye gönderin.
Bir sunucu uygulaması yazacağınızı varsayarsak, işte kod parçası.
public void doGet(HttpServletRequest request,
HttpServletResponse response) throws IOException, ServletException {
String targetId = request.getParameter("id");
if ((targetId != null) && !accounts.containsKey(targetId.trim())) {
response.setContentType("text/xml");
response.setHeader("Cache-Control", "no-cache");
response.getWriter().write("<valid>true</valid>");
} else {
response.setContentType("text/xml");
response.setHeader("Cache-Control", "no-cache");
response.getWriter().write("<valid>false</valid>");
}
}
Geri Arama İşlevi processRequest () Çağrıldı
XMLHttpRequest nesnesi için bir durum değişikliği olduğunda ProcessRequest () işlev çağrısı için yapılandırılmış readyState arasında XMLHttpRequest nesne. Şimdi bu işlev sonucu sunucudan alacak ve gerekli işlemi yapacaktır. Aşağıdaki örnekte olduğu gibi, Web sunucusundan döndürülen değere göre bir değişken mesajını doğru veya yanlış olarak ayarlar.
function processRequest() {
if (req.readyState == 4) {
if (req.status == 200) {
var message = ...;
...
}
HTML DOM Güncellendi
Bu son adımdır ve bu adımda HTML sayfanız güncellenecektir. Aşağıdaki şekilde olur -
- JavaScript, DOM API kullanarak bir sayfadaki herhangi bir öğeye referans alır.
- Bir elemana referans almanın önerilen yolu çağırmaktır.
document.getElementById("userIdMessage"),
// where "userIdMessage" is the ID attribute
// of an element appearing in the HTML document
JavaScript artık elementin niteliklerini değiştirmek için kullanılabilir; öğenin stil özelliklerini değiştirebilir; veya alt öğeleri ekleyin, kaldırın veya değiştirin. İşte bir örnek -
<script type = "text/javascript">
<!--
function setMessageUsingDOM(message) {
var userMessageElement = document.getElementById("userIdMessage");
var messageText;
if (message == "false") {
userMessageElement.style.color = "red";
messageText = "Invalid User Id";
} else {
userMessageElement.style.color = "green";
messageText = "Valid User Id";
}
var messageBody = document.createTextNode(messageText);
// if the messageBody element has been created simple
// replace it otherwise append the new element
if (userMessageElement.childNodes[0]) {
userMessageElement.replaceChild(messageBody, userMessageElement.childNodes[0]);
} else {
userMessageElement.appendChild(messageBody);
}
}
-->
</script>
<body>
<div id = "userIdMessage"><div>
</body>
Yukarıda belirtilen yedi adımı anladıysanız, AJAX ile neredeyse işiniz bitti demektir. Sonraki bölümde XMLHttpRequest nesnesini daha detaylı göreceğiz .