JavaScript, yaygın olarak web tarayıcılarında kullanılmakta olan bir betik dilidir. JavaScript ile yazılan istemci tarafı betikler sayesinde tarayıcının kullanıcıyla etkileşimde bulunması, tarayıcının kontrol edilmesi, asenkron bir şekilde sunucu ile iletişime geçilmesi ve web sayfası içeriğinin değiştirilmesi gibi işlevler sağlanır. JavaScript, Node.js gibi platformlar sayesinde sunucu tarafında da yaygın olarak kullanılmaktadır.
İlk olarak bir Netscape çalışanı olan Brendan Eichtarafından geliştirilen ve 1997 yılından beri bir ECMA standardı olan JavaScript, günümüzde Mozilla Vakfıöncülüğünde özgür yazılım topluluğu tarafından geliştirilmekte ve bakımı yapılmaktadır.
Web sayfalarının görünümünün mükemmelleştirilmesi, işlevselliğinin artırılması ve dinamik web sayfaları tasarlanması amacıyla JavaScript, HTML kodu içinde gömülü olarak (embedded) kullanılabilir. JavaScript, bir programlama dili disiplini ve özelliklerine sahiptir.
Aralarında isim benzerliği olmasına rağmen, Java ile JavaScript arasında teknik olarak çok önemli farklılıklar mevcuttur. Aşağıdaki tabloda bu farklılıklar vurgulanmaktadır:
JavaScript | Java |
İstemci (client) tarafından (örn. web tarayıcı) yorumlanır (derlenmez). | Derlenmiş bytecode denilen program istemcide çalıştırılır. |
Nesneye dayalı bir dildir. Nesne tipleri arasında farklılık yoktur. Herhangi bir nesneye yeni özellik ve metotlar dinamik olarak eklenir. Nesneye yönelik teorinin miras alma (inheritance) özelliği prototip mekanizmasıyla gerçekleştirilir. | Nesneye yönelik bir dildir. Nesneler çeşitli sınıflara ayrılmıştır ve miras alma mekanizması, sınıf hiyerarşisi sayesinde gerçekleştirilir. Sınıf ve sınıf örneklerine özellik ve metotlar dinamik olarak eklenemez. |
Değişken veri tip bildirimi mekanizması yoktur. | Değişken tip bildirimi zorunludur. |
Dinamik bağlama mekanizması kullanılır yani nesneye verilen referanslar çalışma zamanında (run time) kontrol edilir. | Statik bağlama mekanizması kullanılır yani nesne referansları derleme zamanında (compile time) kontrol edilir. |
Betik dili, web sayfalarında dinamik içerik sağlamak ve kullanıcıyla iletişim kurmak için kullanılan, istemci tarafında çalışan bir dildir. Html etiketleri arasında tanımlanarak kullanılabilir.
HTML’e JavaScript Kodlarını Tanıtma
Script kodlarını html’e tanıtmak için;
[code language=”html”]
<script laguage="javascript" type="text/javascript">
…..
….
….
</script>
[/code]
Yukarıdaki tanımlamada kullanılan Type parametresi script blokları arasında yazılacak kodların türünü belirtir. Language parametresi ile JavaScript kodlarının sürümünü (javascript 1.0, javascript 1.2,javascript 1.5, vs.) belirtir. Tümtarayıcılarda sorunsuz çalışması için JavaScript seçmek doğru olacaktır
JavaScript Kodlarının HTML’deki Konumu
JavaScript Kodlarının HTML’deki Konumu JavaScript kodları sayfa içerisinde üç şekilde kullanılabilir:
Birinci yol, script kodlarını için <head>…</head> etiketleri arasına yazarak kullanmaktır. etikletleri arasında yazılan kodlar sayfa yüklenmeden derlenecektir. Sayfamızda gerçekleşen olaylar karşısında (düğme tıklanması vb.) kodların çalışmasını istiyorsak gerekli fonksiyonları ve değişkenleri bu bölümde yazmamız gereklidir.
[code language=”html”]
<!DOCTYPE html>
<html>
<head>
<script laguage="javascript" type="text/javascript">
…..
….
….
</script>
</head>
<body>
..
..
</body>
</html>
[/code]