AJAX - Tarayıcı Desteği
Mevcut tüm tarayıcılar AJAX'ı destekleyemez. AJAX'ı destekleyen başlıca tarayıcıların listesi burada.
- Mozilla Firefox 1.0 ve üstü.
- Netscape sürüm 7.1 ve üstü.
- Apple Safari 1.2 ve üzeri.
- Microsoft Internet Explorer 5 ve üzeri.
- Konqueror.
- Opera 7.6 ve üzeri.
Bir sonraki uygulamanızı yazarken, AJAX'ı desteklemeyen tarayıcıları göz önünde bulundurun.
NOTE - Bir tarayıcının AJAX'ı desteklemediğini söylediğimizde, bu sadece tarayıcının Javascript nesnesinin - XMLHttpRequest nesnesinin - oluşturulmasını desteklemediği anlamına gelir.
Tarayıcıya Özel Kod Yazma
Kaynak kodunuzu bir tarayıcıyla uyumlu hale getirmenin en basit yolu , JavaScript'inizde try ... catch bloklarını kullanmaktır .
<html>
<body>
<script language = "javascript" type = "text/javascript">
<!--
//Browser Support Code
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;
}
}
}
}
//-->
</script>
<form name = 'myForm'>
Name: <input type = 'text' name = 'username' /> <br />
Time: <input type = 'text' name = 'time' />
</form>
</body>
</html>
Yukarıdaki JavaScript kodunda, XMLHttpRequest nesnemizi yapmak için üç kez deniyoruz. İlk denememiz -
- ajaxRequest = new XMLHttpRequest ();
Opera 8.0+, Firefox ve Safari tarayıcıları içindir. Başarısız olursa, bir Internet Explorer tarayıcısı için doğru nesneyi yapmak için iki kez daha deneriz -
- ajaxRequest = new ActiveXObject ("Msxml2.XMLHTTP");
- ajaxRequest = new ActiveXObject ("Microsoft.XMLHTTP");
Çalışmazsa, XMLHttpRequest'i desteklemeyen çok eski bir tarayıcı kullanabiliriz, bu da AJAX'ı desteklemediği anlamına gelir.
Büyük olasılıkla, ajaxRequest değişkenimiz , tarayıcının kullandığı XMLHttpRequest standardına göre ayarlanacaktır ve sunucuya veri göndermeye başlayabiliriz. Adım adım AJAX iş akışı sonraki bölümde açıklanmaktadır.