21 Mart 2007 00:59# 1
Üyelik : 19.10.2006
Yaş : 35
Şehir : İzmir
Mesaj Sayısı : 497
Konu : Javascript Full kod, ders ve dökümanlar
Javascript?le Tanışalım

Javascript, HTML?in bir parçasıdır ve içinde bulunduğu HTML ile birlikte Web Browser programı tarafından yorumlanır. Dolayısıyla, Javascript programı yazmak demek, bir Web sayfası hazırlamak ve bu sayfadaki HTML kodlarının arasına Javascript kodları gömmek demektir.

İlk Javascript programımızı yazalım. Şu kodu yazıp, merhaba1.htm adıyla kaydedin:




Merhaba Dünya!


Merhaba Dünya

<FORM>
TIKLAYINI!




Sonra ya bu dosyayı iki kere tıklayın; ya da favori Browser programınızı çalıştırın ve bu dosyayı açın. Karşınıza çıkacak düğmeyi tıklayın. İşte sonuç:
Bütün Web sayfaları gibi, Javascript kodunuzun yer aldığı sayfa da tipik bir HTML kod kümesi:
1. Browser programına kendisinin bir HTML dosyası olduğunu birinci satırda beyan ediyor; ve bittiği yer açıkça gösteriliyor.
2. HTML kodu iki bölüm içeriyor: Başlık (Head) ve gövde (BOdy) bölümleri. Her bölümün nerede başladığı ve nerede bittiği açıkça belirtiliyor.
3. Gövde bölümünde bir Form unsuruna yer veriliyor; fakat bu formun tek ögesi var: Düğme (Button).
4. Daha önce Web sayfalarınıza düğme koyduysanız, bu düğmenin onlardan farklı bir tarafı var: Türü, değeri, vs. belirtilmiyor; sadece ?onclick="alert(?Merhaba Dünya!?)" şeklinde bir ifadeye yer veriliyor.
5. Ve ilk Javascript programınızda ne Javascript?in adı geçiyor; ne de HTML ile Javascript bölümlerini birbirinden ayırteden, <SCRIPT>.. etiketine yer veriliyor!
Javascript?te imla kuralları olmakla birlikte bu kurallara yüzde 100 uymanın zorunlu olmadığını ifade ettik. Kural olarak, Javascript bölümü, HTML?in içine <SCRIPT>.. etiketlerinin arasına gömülür. İşte size bütün kuralları yerine getirilmiş bir Javascript bölümü yazma örneği:




Merhaba Dünya!
<SCRIPT LANGUAGE=?Javascript1.2?>



Merhaba Dünya

<FORM>
TIKLAYINI!




Bu metni merhaba2.htm adıyla kaydeder ve Browser?ınızda açarsanız, görüntünün ve işlevin tıpatıp aynı olduğunu göreceksiniz. İki metin arasındaki fark, ikincisinin Javascript yazma kurallarına yüzde 100 uymasından ibaret. Bununla birlikte Javascript ile HTML?i birbirinden dikkatlice ayırmanız gereken durumlar, ikisinin birbiriyle kaynaştığı noktalardan daha çoktur. Hatta o kadar ki, Javascript?in ileri sürümüne ilişkin komutlar kullanıyorsanız, eski sürüm Browser?ların kafasının karışmaması ve dolayısıyla ziyaretçinizin bilgisayarının kilitlenmemesi için bunu bile belirtmeniz gereken durumlar olabilir.

Bir de şunu deneyin: önce merhaba.js adıyla şu metni kaydedin:

function merhaba()
{
alert("Merhaba, Dünya!")
}

Sonra, merhaba2.htm dosyasında şu değişikliği yapın ve merhaba3.htm adıyla kaydedin:




Merhaba Dünya!
<SCRIPT src= ">


Merhaba Dünya

<FORM>





Ve merhaba3.htm?i açtığınızda yine aynı görüntü ve aynı işlevle karşılaştığınızı göreceksiniz. Bu üçüncü yöntemde sadece Javascript kodlarını içeren ve dosya adının uzatması ?.js? olan bir düzyazı dosyasını HTML?e dışardan da eklemiş olduk.

Javascript?in Temel İlkeleri
Web Browser programları, Javascript komutlarını yorumlayabilmek için, HTML?in içinde <SCRIPT LANGUAGE=?Javascript?> etiketini ararlar ve etiketini gördükleri anda bu yoruma son verir; HTML yorumuna dönerler. Bu etikette, kullanacağınız Javascript sürümünü de belirtebilirsiniz. Javascript, şu anda 1.3?ncü sürümünde. Ancak Netscape 2.0 ve 2.2 ile IE 3.0, Javascript?in 1.0 ve 1.1 sürümlerini tanıyabilir. Her iki Browser?ın 4?ncü sürümleri ise Javascript 1.2 ile uyumludur. Script etiketinde sürüm yazmazsanız, her iki Browser da 1.0 sürümünü kullandığınızı varsayar. Netscape ileri sürümlere ait komutları (eğer tanıyorsa) icra eder, tanımıyorsa görmezden gelir. IE ise belirttiğiniz sürümden ileri komutları tanımaz ve hata mesajı verir. Kullanılan Browser türleri ve sürümlerine ilişkin istatistikler dikkate alınırsa, bu satırları kaleme aldığımızda en güvenli sürüm 1.2?dir.

Javascript Yazım Kuralları

Browser?ların Javascript yorumlama bölümleri, kodların arasında yer alan yorum ifadeleri ile boşlukları atar; geri kalan kelimeleri beşe ayırarak ele alırlar:

1. Belirleyiciler (Identifier):

Javascript dilinin değişkenleri, metodları ve nesnelerini belirleyen isimlere Belirleyiciler denir. Bu sınıfa giren bütün kelimeler ya harfle ya da alt çizgi (_) ile başlar. Rakam veya diğer işaretler birinci karakter olarak kullanılamaz, fakat daha sonra kullanılabilir. Javascript, aynı kelimenin büyük harfle yazılanı ile küçük harfle yazılanını farklı isimler olarak görür. Bu sınıfta giren kelimelerin içinde boşluk olamaz.

Javascript kodlarınız sizin bilgisayarınızda değil, ziyaretçinin bilgisayarında çalıştırılacağına göre, kullandığınız karakterlerin ziyaretçinin bilgisayarında nasıl bir değer taşıyacağını düşünmeniz gerekir. Bu bakımdan güvenli yol, Bu sınıfa giren kelimelerde, İngilizce alfabede bulunmayan, Türkçe ve diğer dillerdeki high-ASCII karakterleri (ı, İ, ğ, Ğ, Ş, Ş ile ü, Ü, ö, Ö, ç ve Ç) kullanmamaktır.

Aşağıda doğru ve yanlış belirleyici kelime örneklerini bulacaksınız:

Doğru Yanlış
sonucgoster sonuc goster
ikincidegisken 2ncidegisken
_gelen #gelen

Anahtar kelime grubundaki kelimeler de bu sınıfta kullanılamaz.

2. Anahtar Kelimeler (Keyword):

Javascript dilinin önceden tanımlanmış ve programın yorumunda özel anlam kazandırılmış kelimelerine Anahtar Kelime denilir. Aşağıda bu kelimelerin yanında kelime anlamlarını göreceksiniz; fakat ilerledikçe bu kelimelerin Javascript?te kullanıldıkları yere göre anlamlarını ve nerelerde kullanıldıklarını göreceğiz.

Javascript 1.0?deki anahtar kelimeler:
break (kes)
continue (devam et)
else (başka bir durum)
false (yanlış)
for (için)
function (işlev)
if (eğer)
in (içinde)
int (integer, tam sayı)
new (yeni)
null (boş değer)
return (dön)
this (bu)
true (doğru)
var (variable, değişken)
while (... iken)
with (ile)
Javascript 1.i ile eklenen anahtar kelimeler:
typeof (türü)
void (geçersiz)
Javascript 1.2 ile eklenen anahtar kelimeler:
do (yap)
labeled (etiketli)
switch (değiştir)

3. Ayrılmış Kelimeler (Reserved):

İkinci gruba girsin-girmesin bazı kelimeler, ilerde Javascript programlama ve yorumlama işlerinde kullanılabileceği düşüncesi ile, bir kenara ayrılmıştır; Javascript kodlarında kullanılamazlar. Bu listede yer alan ve halen Anahtar Kelime listesine girmiş bir kelime değişken, fonksiyon, nesne veya metod adı olarak kullanılırsa, program hata verir; henüz anahtar kelime listesine alınmamış olmakla birlikte ?rezerv edilmiş? bu kelimelerin geçtiği komut satırı ise görmezden gelinir. Javascript programlarınızda kullanmayacağınız kelimelerin listesi şöyledir:

abstract (soyut)
boolean (Boolean Mantığı)
break (kes)
byte (bayt)
case (hal)
catch (yakala)
char (karakter)
class (sınıf)
const (sabit)
continue (devam)
default (varsayılan)
delete (sil)
do (yap)
double (çift)
else (başka bir durum)
extends (uzanır)
false (yanlış)
final (sonuncu)
finally (sonunda)
float (kesirli)
for (için)
function (işlev)
goto (--ya git)
if (eğer)
implements (uygular)
import (ithal et)
in (içinde)
instanceof (--nın oluşumu)
int (integer, tam sayı)
interface (arayüz)
labed (etiketli)
long (uzun)
native (kendinden olan)
new (yeni)
null (boş değer)
package (paket)
private (özel)
protected (korunmuş)
public (genel)
return (dön)
short (kısa)
static (sabit)
super (kuvvet)
switch (değiştir)
synchronized (uyumlu)
this (bu)
throw (içine kat)
throws (içine katar)
transient (geçici)
true (doğru)
try (dene)
typeof (türü)
var (değişken)
void (geçersiz)
while (iken)
with (ile)

4. Değerler (Literal):

Javascript kodu icra edildiği sırada değişmeyen rakam veya metinlere Değer denir. Javascript kodlarında beş tür değer bulunur:
a. Tamsayı Değerler (Integer Literal):
Tamsayılar, 10 tabanlı (ondalık, decimal), 8 tabanlı (octal) veya 16 tabanlı (hexadecimal) olabilir. 8 tabanlı sayıları belli etmek için sayıdan önce sıfır, 16 tabanlı sayıları belli etmek için sıfır ve x harfi kullanılır. Hexadecimal sayılarda 9?dan büyük sayılar A, B, C, D, E ve F harfleri ile yazılır. (Sayının basamaklarını okuma kolaylığı sağlamak için, nokta değil, virgül ile ayırmalısınız.) Örnek: Decimal 46,789; Octal 072,7898; Hexadecimal: 0x7B8.

b. Kesirli Değerler (Floating-point literal):
Tam sayı bölümünü bir ondalık nokta (virgül değil) ile kesir bölümü izleyen sayılar. Örnek: 3987.786, -1.1.

c. Boolean Mantık İfadeleri (Boolean Literal):
Javascript dilinde, Boolean Mantığı, iki sonuç verir: True (Doğru) ve False (Yanlış). Javascript, True (Doğru) değerini 1, False (Yanlış) değerini 0 rakamıyla tutar. Bir denklemin sonucunun doğru veya yanlış olduğunu irdelerken, Javascript metninde bu iki kelime küçük harfle yazılmalıdır. Dolayısıyla büyük harfle yazılmış TRUE ve FALSE kelimeleri, değişken, fonksiyon, nesne ve metod adı olarak kullanılabilir. Tabii, bir süre sonra kafanız karışmazsa!

d. Alfanümerik (Karakter) Değerler (String literal):
İki adet çift-tırnak (?) veya tek-tırnak (?) içine alınan her türlü ifade, Javascript için String değeridir. (Çeşitli Türkçe bilgisayar kaynaklarında ?String literal? terimi ?karakter değişken? olarak belirtilmektedir. ?Karakter? bu değerlerin örneğin sayı değerlerden farkını anlatmıyor. Bazı kaynaklarda ise hem rakam, hem de harf içerdikleri, buna karşılık sayı olmadıkları gerçeğini belirtmek amacıyla, daha aşina olduğumuz alfanümerik terimini görmek mümkün. Ben bu ikincisini benimsiyorum.) Bir Javascript metninde alfanümerik değerleri bir tek tırnakla, bir çift tırnakla gösteremezsiniz. Başta nasıl başladıysanız, programın sonuna kadar bütün alfanümerik değerleri aynı tür tırnak içinde göstermelisiniz. Alfanümerik değer olarak verdiğiniz karakterler, daha sonra bir HTML sayfada bir nesnenin bir unsurunun değeri (örneğin bir TEXTAREA?nın içeriği) olarak kullanılacaksa ve HTML sayfa, meta etiketlerinde kendisinin Türkçe olarak yorumlanmasını sağlayacak ifadeye sahipse, Türkçe karakter ve diğer yüksek ASCII kodlardaki karakterleri içerebilir. Örnekler: ?Bugün hava çok güzel? ?Bugün hava güzel değil? ?123 adet yumurta? ?23,234,678.987?

e. Özel Karakterler
Özellikle alfanümerik değerleri verirken, Browser?a metin görüntüleme konusunda biçim veya hareket komutları da vermek isteyebilirsiniz. Bunu, bazı kod harflerin önüne ters-bölü işareti koyarak yapabilirsiniz. Bu tür özel karakterler şunlardır:
 - Klavyede Geri (backspace) tuşunun görevini yaptırır.
f - Yazıcıya sayfayı bitirmeden çıkarttırır (formfeed).

- Yazı imlecini yeni bir satırın başına getirir (new line)

- Klavyede Enter-Return tuşunun görevini yaptırır.
- Sekme (tab) işaretini koydurur.
- Yazıya ters-bölü işareti koydurur.
? - Yazıya tek-tırnak işareti koydurur.
? - Yazıya çift-tırnak işareti koydurur.
Javascript?e bu tür özel karakterlerle HTML sayfasına bir metin yazdıracağınız zaman, bu yazının
..
etiketleri arasında olması gerekir. Aksi taktirde Javascript ne yazdırırsa yazdırsın, HTML bu özel karakterleri dikkate almayacaktır.

Javascript Değişkenleri (Variable)
Değişken, adı üstünde, Javascript yorumlayıcısı tarafından bilgisayarın belleğinde tutulan ve içerdiği değer programın akışına göre değişen bir unsurdur. Değişkenlerin bir adı olur, bir de değeri. Program boyunca beğişkenin adı değişmez; fakat içeriği değişebilir.
Değişkenlere isim verirken Belirleyici isimleri kurallarına riayet etmeniz gerekir. Yani bir değişkenin adı rakamla veya alt çizgi (_) dışında bir işaretle başlayamaz. Javascript, büyük harf-küçük harf ayırt ettiği (case-sensitive olduğu) için, örneğin SONUC ve sonuc kelimeleri iki ayrı değişken gösterir. Bir değişkeni tanımlarken, büyük harf kullandıysanız, program boyunca bu değişkeni büyük harle yazmanız gerekir.
Değişken tanımlamak, bilgisayar programcılarına daima gereksiz bir yük gibi görünür. Birazdan göreceğiz, Javascript sadece değişkenleri tanımlamayı zorunlu kılmakla kalmaz, fakat nerede tanımlandığına da özel bir önem verir. Javascript?e bir Belirleyici?nin değişken olarak kullanılacağını bildirmek için ?var? anahtar-kelimesini kullanırsınız:

var sonuc
var adi, soyadi, adres, siraNo
var i, j, k
var mouseNerede, kutuBos, kutuDolu

Gördüğünüz gibi, bir ?var? satırında birden fazla değişken tanımlayabilirsiniz.
Bazı diğer programlardan farklı olarak Javascript, size değişkenleri hem beyan, hem de içeriğini belirleme işini aynı anda yapma imkanı veriyor (initialization):

var sonuc = ?Merhaba Dünya!?
var adi = ?Erhan?, soyadi = ?BAYRAK?
var i = 100, j = 0.01, k = 135
var kutuBos = false, kutuDolu = true

Gerekiyorsa, bir değişkeni önce tanımlar, sonra değerini belirleyebilirsiniz:

var kutuBos = false, kutuDolu
kutuDolu = true

Javascript, programcıya bir değişkeni tanımlamadan ?initalize etme? (içine doldurma) imkanı da verir; bu durumda o değişken genel (global) nitelik kazanır. Buna birazdan değineceğiz; ama iyi programlama tekniği ve özellikle daha sonra hata arama zorunluğu sebebiyle, değişkenlerin açık-seçik tanımlanması en doğru yoldur.
Bir değişkeni tanımlayarak içini doldurmadan (initialization?dan) önce içindeki değeri sorgulamaya kalkarsanız, Browser?ın Javascript yorumlayıcısı o noktada durur ve tanımlanmamamış (undefined) değişken hatası verir.
Javascript programlarında beş tür değişken bulunabilir:
__________________
21 Mart 2007 00:59# 2
Üyelik : 19.10.2006
Yaş : 35
Şehir : İzmir
Mesaj Sayısı : 497
Cevap : Javascript Full kod, ders ve dökümanlar
. Sayı (number): -14, 78, 87678

Sayı türündeki değişkenler, tam sayı, ondalık sayı, pozitif sayı veya negatif sayı olabilir. Sayı değişkenlerle aritmetik işlemler yapılabilir.

var eni = 9, boyu = 4
var alani = eni * boyu
***************ln(alani)

Bu kod örneği ile Javascript, Browser penceresi içindeki belgeye ?alani? adlı değişkenin değerini (36) yazdıracaktır.

2. Boolean değişken: true, false

Javascript, tanımlanırken değeri ?true? (doğru) veya ?false? (yanlış) olarak belirtilen değişkenleri otomatik olarak Boolean değişken olarak sınıflandırır ve sorguladığınızda ?true? için 1, ?false? için 0 değerini verir.

3. Alfanümerik (String) Değişken: ?Merhaba Dünya!?

Alfanümerik değişken, kendisine tek veya çift tırnak içinde verilen bütün karakterleri tutar, ve sorulduğunda aynen bildirir. Alfanümerik değişkenin içi boş olabilir (var adi = ??, soyadi = ??). Alfanümerik değişkenler, tabir yerinde ise ?toplandığında? değişkenlerin değerleri sırayla birbirine eklenir:

var adi = ?Osman?, soyadi = ?Hömek?
var adisoyadi = adi + soyadi
***************ln(adisoyadi)

Bu kod örneği ile Javascript, Browser penceresi içindeki belgeye ?adisoyadi? adlı değişkenin değerini (OsmanHomek) yazdıracaktır. Araya boşluk koymanın tekniğine ilerde değineceğiz!

4. İşlev (Function) Değişken:

Javascript?in hayatî noktası fonksiyonlardır. Javascript?e fonksiyonlarla iş yaptırırız. Kimi fonksiyonu, Javascript?i tasarlayanlar bizim için tanımlamışlardır; bunlara metod denir. (Kimi metod, ne yapacaksa bizim hiç bir katkımızı beklemeden yapar; kimi metod mutlaka bizden bir katkı bekler.) Kimi fonksiyonları biz tanımlarız ve komutlarını biz veririz. Bunlara ?Programlanan Fonksiyonlar? denir. Başlarda yazdığınız ve merhaba2.htm adıyla kaydettiğiniz dosyada biz ?merhaba()? adlı bir fonksiyon oluşturduk; sonra bu fonksiyona bir otomatik fonksiyon olan alert() metodunu kullanmasını bildirdik; bu otomatik fonksiyona da görevini yaparken kullanmasını istediğimiz değeri verdik!

5. Nesne (Object) değişkenleri: window, document
Bu tür değişkenlere değişken adını vermek bile gerekmez; çünkü bunlar Browser?ın nesneleridir. Fakat Javascript kodlarımızda bu nesneleri de değişken gibi kullanabiliriz. Bu sınıfa giren özel bir değişken ise değerini ?null? (içi boş) kelimesiyle belirlediğiniz değişkenlerdir.
Javascript, değişkenlerini bu beş sınıfa ayırmakla birlikte sizden değişkenlerinizi sınıflamanızı beklemez. Sınıflamanın önemi, daha sonra, programın ileri bir aşamasında bir değişkenin değeri ile yaptıracağınız işlemde ortaya çıkacaktır. Bir değişken, kendi sınıfının yapamayacağı bir işleme veya sorgulamaya tabi tutulursa, Javascript size pek de kibarca olmayan bir hata mesajı ile değişkeni doğru kullanmadığınızı hatırlatacaktır.
Bununla birlikte bir fonksiyonda sayı olarak tanımlanmış ve doldurulmuş bir değişken, aynı fonksiyonda daha sonraki bir işlemde veya başka bir fonksiyonda alfanümerik değişken olarak tanımlanabilir ve doldurulabilir. Bu değişken sorgulandığında değerini, yetki alanı (scope) çerçevesinde bildirir.
Değişkenlerin yetki alanı veya geçerli olduğu alan (scope), oluşturulmuş ve değeri belirlenmiş olduğu sahayı, yani kendisine atıfta bulunulduğu zaman bildireceği değerini ve bu değişkene nerelerden atıfta bulunulabileceğini gösterir. Şimdi, HTML dosyasının baş tarafında (HEAD etiketi içinde) bir değişkeni tanımladığınızı ve ona bir değer verdiğinizi düşünün. Daha sonra yazacağınız bütün fonksiyonlarda veya değerini belirleyebileceğiniz otomatik fonksiyonlarda (metod?larda) bu değişkeni bir daha tanımlamaya ve değerini belirlemeye gerek kalmadan kullanabilirsiniz; çünkü Javascript açısından bu değişken genel (global) değişken sayılır. Daha sonra ayrıntılı olarak göreceğimiz gibi, HTML?in gövde kısmında (BODY etiketi içinde) bir fonksiyon yazdığımızı ve bu fonksiyonun içinde bir değişken tanımladığımızı düşünün. Daha sonra yazacağınız bir fonksiyonda bu değişkeni kullanamazsınız; çünkü Javascript bir fonksiyonun içindeki değişkeni yerel (local) değişken sayar ve kendi yetki alanı (scope?u) dışında kullanmanıza izin vermez. Bir yerel değişken, ait olduğu fonksiyon çağrıldığı anda oluşturulur ve fonksiyonun icrası bittiği anda yok edilir. Dolayısıyla bir fonksiyon, başka bir fonksiyonun yerel değişkinini kullanmaya kalktığında ?undefined? (tanımlanmamış) değişken hatasıyla karşılaşırsınız.
Bir değişkeni bütün HTML sayfası boyunca kullanmayı düşünüyorsanız, bu değişkeni, HTML sayfasının başında içinde fonksiyon bulunmayan bir SCRIPT bölümünde tanımlamalı ve doldurmalısınız. İyi bir programlama tekniği, genel değişkenleri, açık-seçik tanımlamak ve bunu yorum satırıyla belirtmektir:




Merhaba Dünya!
<SCRIPT LANGUAGE="Javascript1.2">



BURAYA ÇEŞİTLİ AMAÇLARLA HTML KODLARI GİREBİLİR!! SONRA TEKRAR SIRA JAVASCRIPT?E GELEBİLİR


<SCRIPT LANGUAGE="Javascript1.2">




Merhaba Dünya

<FORM>





Bu kodu da merhaba6.htm adıyla kaydedebilirsiniz. Daha sonra merhaba fonksiyonunda ?alert(metin1)? satırındaki 1 rakamını 2 ve 3 diye değiştirirseniz, merhaba6.htm?in uyarı kutusunun içeriğini değiştirdiğini göreceksiniz. Şimdi, merhaba6?da merhaba() fonksiyonunu şöyle değiştirin ve şu eki yapın:

function merhaba()
{
var metin1 = "Sana da merhaba!"
alert(metin1)
}
function hello()
{
alert(metin1)
}

Sonra, aynı dosyada mevcut düğme oluşturan INPUT satırının altına şu satırı ekleyin; sayfanızda iki düğme görünecektir:



Bu düğmelerden birincisi, merhaba() fonksiyonunu, ikincisi hello() fonksiyonunu çağıracak. Genel olarak tanımladığınız ve değer verdiğiniz metin1 değişkeninin değerini merhaba() fonksiyonunda değiştirdiniz; bu değişkenin yeni değeri ?Sana da merhaba!? şeklini aldı. Bu metni, merhaba7.htm adıyla kaydedip, Browser?da açtığınızda ve birinci düğmeyi tıkladığınızda, uyarı kutusunun içeriğinin metin1 değişkeninin genel değerini değil yerel değerini içerdiğini göreceksiniz. Yani metin1?in değeri değişmiş oldu. Peki, ikinci düğmeyi tıklayın! metin1?in değeri değişmemiş gibi, uyarı kutusunun genel tanımlamadaki değeri kullandığını göreceksiniz. Oysa biraz önce, birinci düğmeyi tıkladığımızda yani merhaba() fonksiyonu çalıştığında metin1?in değeri değişmemiş miydi? Şimdi neden eski metin1?in eski değeri karşımıza çıkıyor?
Bu alıştırmanın öğrettiği kural şöyle özetlenebilir: Bir genel değişken, bir fonksiyon içinde yerel olarak değiştirilebilir; ama onun genel değeri diğer fonksiyonlar için geçerli kalır. Javascript programlarınızı yazdığınız zaman genel değişkenleriniz beklediğiniz değeri vermiyorsa bu değeri bir fonksiyonun yerel olarak, sırf kendisi için, değiştirip değiştirmediğine bakmalısınız. Bu tür hatalardan kaçınmanın bir yolu, yerel değişkenlerinizle genel değişkenlerinize farklı isimler vermektir.
Javascript, değişkenlerinizi isimlendirmede rakamla ve işaretle başlamamak dışında kural koymuyor; ama iyi programcılık tekniği, değişkenlere anlaşılır ve kullanıldığı yeni belli eden isimler vermektir. Örneğin, ?adi? şeklindeki bir değişken adı, çok değişkenli bir Javascript programında yanıltıcı olur. ?musteri_adi? veya ?musteriAdi? çok daha uygun olabilir. Ayrıca değeri ?Evet? (=doğru, true) veya ?Hayır? (=yanlış, false) olan Boolean değişkenlerin adlandırılmasında, örneğin, ?doluMu,? ?tamamMi,? ?acikMi,? ?bittiMi? gibi cevabı çağrıştıran değişken adları kullanabilirsiniz.
Javascript, değişkenlerinizi isimlendirmede rakamla ve işaretle başlamamak dışında kural koymuyor; ama iyi programcılık tekniği, değişkenlere anlaşılır ve kullanıldığı yeni belli eden isimler vermektir. Örneğin, ?adi? şeklindeki bir değişken adı, çok değişkenli bir Javascript programında yanıltıcı olur. ?musteri_adi? veya ?musteriAdi? çok daha uygun olabilir. Ayrıca değeri ?Evet? (=doğru, true) veya ?Hayır? (=yanlış, false) olan Boolean değişkenlerin adlandırılmasında, örneğin, ?doluMu,? ?tamamMi,? ?acikMi,? ?bittiMi? gibi cevabı çağrıştıran değişken adları kullanabilirsiniz.

Dizi-Değişkenler (Array)

Javascript?in şu ana kadar ele aldığımız bütün değişkenleri, tekildir. Yani bu değişkenlerden Javascript bakımından sadece bir adet vardır; dolayısıyla bir adet de değeri bulunur.
Oysa şimdi şöyle bir durum düşünün: Evcil kuşları tanıttığınız bir site yapıyorsunuz. Ele alacağınız bütün kuşları ve özelliklerini bir tablo olarak düşünebilir misiniz? Kuş-1: Kanarya, Kuş-2: Bülbül, Kuş-3: Muhabbet Kuş-4: Papağan, gibi. Bunların hepsini tek tek tanımlamaya kalkarsak, daha sonra kullanım zorluğu doğabilirdi. Javascript, bize ?dizi-değişken? (Array) yoluyla, örneğin bir ?kuş? değişkeni oluşturup, bunun içine istediğimiz kadar değer koyma imkanı veriyor. Bir dizi-değişkenin bireylerinin değerlerini dizi-değişkenin endeksi ile çağırabilir veya belirleyebilirsiniz.

Bir dizi-değişken oluşturmanın formülü şudur:

var dizinin_Adı = new Array(unsur1, unsur2, unsur3...unsurN)
Bu formüle göre, kuş dizisini şöyle oluşturabiliriz:
var kusDizi = new Array(bülbül, kanarya, muhabbet, papagan)

Diziler (nedendir, bilinmez) sıfırdan itibaren numaralanır; yani bizim örneğimizde dizinin birinci üyesi kusDizi[0], ikinci üyesi kusDizi[1], üçüncü üyesi kusDizi[2], dördüncü üyesi ise kusDizi[3] diye anılır. Burada örneğin kusDizi[2] değişkeni ?muhabbet? değerini taşır. İlerde bu değeri değiştirmek ve diyelim ki ?Saka? yapmak istersek, Javascript kodumuzun uygun yerinde şunu yazarız:

kusDizi[2]=?saka?

Dizi-değişkenleri, özellikle ele almamızın bir nedeni, dizilerin Javascript açısından nesne sayılmasıdır. Bunun önemine ve kullanıldığı yerlere daha sonra değineceğiz; şimdilik şunu belirtelim: dizi-değişkenlerin, nesne oldukları için özellikleri (property) vardır. Örneğin, oluşturduğum dizi-değişkenin kaç üyesi olduğu, ?kusDizi.length? özelliğinin içinde yazılıdır. İlerde dizi-değişkenlerimizin üye sayısından çok yararlanacağız.

Javascript?te İşlemler (Operator)

Program yazmanın amacı, bilgisayara işlem yaptırtmaktır. Javascript de bu açıdan farklı değildir: bir değişkenin değerini alırsınız, bir işlemden geçirirsiniz; sonra ortaya çıkacak yeni değeri ya bildirirsiniz, ya da yeni bir işlemde kullanırsınız. Tabiî herşey bu kadar kolay olsa idi, herkes programcı olurdu. Herkes programcı olmadığına göre, söz gelimi ?bir değişkeni almak? için önce değişkenin değerinin nereden ve nasıl elde edileceğini bulmanız gerekir. Ayrıca yukarıda öğrendik ki, Javascript programları Browser?ın pencere nesnesine veya penceresinde de görüntülediği belge nesnesinin bir unsuruna hitaebeder. Dolayısıyla hangi nesnenin ne gibi nitelikleri olduğunu öğrenmemiz gerekir ki, işleme tabi tuttuğumuz değerleri bu unsurların işine yarayacak şekle getirelim.
Javascript, eline verdiğiniz değişkenin türüne ve değişkenin değerine göre dört tür işlem yapar. Şimdi bunları sırasıyla ele alalım:

Atama (Assignment) İşlemleri:

Javascript?te en sık yapacağınız işlem, bir değişkene bir değer atama işlemidir: ?Adı? adlı değişkenin değeri ?Hakkı? olsun! ?Soyadı? adlı değişkenin değeri ?Öcal? olsun, gibi. Ve tahmin ettiğiniz gibi bunu eşittir (=) işaretiyle yaparız:

var adi = ?Ahmet?, soyadi = ?Arif?
var siraNo = 123, sigortaNo = ?A123-2345-234?

Javascript, bir eşittir işaretiyle karşılaştığında, önce işaretin sağına bakar ve değeri okur; sonra işaretin soluna bakar ve bu adın, meşru bir değişkene ait olup olmadığını ve bu adla bilgisayarın belleğinde bir yer açıp açamayacağını belirler. Eğer işaretin solundaki isim, meşru, yani önceden tanımlanmış veya değeri belirlenmiş bir değişkene ait ise, o değişkenin bilgisayarın belleğindeki adresine işaretin sağındaki değeri yazar. Değişken ismi yeni bir meşru isme aitse, Javascript bu değişkeni ?initalize? eder, yani hem yer açar, hem de içine değerini yazar. Değişken ismi kabul edilebilir nitelikte değilse, yani söz gelimi altı çizgi (_) dışında bir işaretle veya rakamla başlıyorsa, içinde boşluk varsa, veya yasaklı kelimelerden biri ise, Javascript hata mesajı verir.

Bu noktada sık yapılan bir hata, başka bir programlama dilinden kalma alışkanlıkla değişkeni sağa, değeri sola yazmaktır: hakki = adi, gibi. Javascript bu durumda da hata mesajı verir; çünkü ?hakki? değişkenine ?adi? değerini atamak için, sayı olmayan bu alfanümerik değerin ya tek, ya da çift tırnak içine yazılması gerekir.

Javascript?te bir değişkene değer atarken, bu değeri mevcut bir veya daha fazla değişkenden de alabilirsiniz:

var i = j + k
var indexNo = siraNo + kategoriNo
var tutariTL = birimFiyatTL * adet

Aritmetik İşlemleri:

İşte lisede matematik dersinde kaytarmamış olduğunuza şükredeceğiniz noktaya geldik: Javascript (veya başka herhangi bir programlama dili) siz formülünü vermedikçe hiç bir hesabı yapamaz; ama dünyanın en çapraşık, en karmaşık formülünü de verseniz, sonucu (bilgisayarınızın hızı ile orantılı olarak) hesaplar.
Tabiî, Javascript, dört temel işlemi yapabilir. toplama işlemini artı işaretiyle (+), çıkartma işlemini eksi işaretiyle (-), çarpma işlemini yıldız (asterisk, *) işaretiyle, ve bölme işlemini düz bölü işaretiyle (/) yaptırırsınız.
Javascript, artı işaretini gördüğü zaman, işaretin hem sağına, hem de soluna aynı anda bakar ve bulduğu iki değeri, sayı ise toplar, alfanümerik ise sağdakinin soldakinin arkasına ekler:

x = 3 + 4

Javascript, bu işlemin sonucu olarak x adlı değişkene 7 değerini atar. Fakat kimi zaman, bir değişkenin mevcut değerini (sıfır bile olsa) belirli bir miktarda arttırmak isteyebilirsiniz. Yani Javascript?e ?x?in mevcut değerine 3 ekle!? demek isteyebilirsiniz. Bunu, ?x = x + 3? diye ifade ederiz. Eğer arttırılacak miktar 1 ise, bunu daha kısa yazmak da mümkündür: ++x.

Javascript çıkartma işleminde de aynı kuralları uygular:

x = 3 - 4
x = x - 3
--x

Değişkenleri 1 arttırma veya 1 eksiltmeye yarayan kısaltmanın üzerinde biraz duralım. İlerde bol bol örneklerini göreceğimiz gibi, Javascript programlarınızda bazı değişkenleri sayaç olarak kullanmak isteyebilirsiniz. Bir işin sonuna geldiğimizi bilebilmek için, diyelim ki 12 kişilik bir adres listesini Javascript?e okutup, sayfaya bir tablo çizdiriyorsak, Javascript?e listenin sona geldiğini belirtebilmek için sayaç rakamı 12 veya 0 oldu ise durmasını emretmek zorundasınız. Bu durumda sayaç olarak kullandığınız değişkenin değerini, her adres okunduğunda 1 arttırmak veya 1 eksiltmek, en kestirme yoldur. Diyelim ki, x?in orijinal değeri 12. Javascript x-- veya --x işlemini gördüğü anda, 12?den 1 çıkartacak ve x?in yeni değeri olarak 11?i atayacaktır. Aynı şekilde ilk değer sıfır ise, x++ veya ++x işlemini gördüğü anda x?in yeni değerini 1 yapacaktır.
Toplama ve çıkartma işlemlerinde yapabileceğiniz başka bir kısaltma ise şöyle yazılır:

x = x + y işlemini kısaltmak için x += y
x = x - y işlemini kısaltmak için x -= y

Bu bölümü bitirmeden önce, bir sayının değerini negatif yapmaktan da söz edelim. Bir değişkene negatif değer atamak için, sayının önüne eksi işareti koymanız yeter: x = -5 gibi. Bir değişkene başka bir değişkenin değerini negatif olarak atamak istiyorsanız, x = -y gibi yazabilirsiniz. y değişkeninin değeri zaten negatif ise, x?e atanan değer pozitif olur.
Belki belirtmek bile gerekmez ama, Javascript, bölü işaretinin solundaki sayıyı, sağındaki sayıya böler; yıldız (asterisk) işaretinin sağındaki ve solundaki sayıları birbiri ile çarpar.
Javascript, alfanümerik değerlerle çıkartma, çarpma ve bölme işlemleri yapmaz; sonucun yerine ?NaN? (Not a Number, Sayı Değil) yazar.

Karşılaştırma İşlemleri:

Javascript dahil, bütün bilgisayar programlarının ortak özelliği, programın bir noktada karar vermesidir: ?Filanca değişken şu değerde ise, falanca değişken ile şunu yap; o değerde değil de, bu değerde ise bunu yap!? gibi. Bu tür komutlarda Javascript, sözünü ettiğiniz değişkenin değerini bulup, onu verdiğiniz bir başka ölçütle karşılaştıracak ve varacağı sonuca göre emrettiğiniz işi yapacaktır. Dolayısıyla Javascript?te bir takım karşılaştırma işlemlerine ihtiyacınız var demektir.
Javascript?in karşılaştırma operatörleri genellikle ?if? (eğer..ise) ifadesiyle birlikte kullanılır; ve bu soruyu soran satıra ?true? (doğru) veya ?false? (yanlış) sonucunu verir. Önce, bu işlemleri yaptırtan operatörleri ve işlevlerini sıralayalım:

== Eşit operatörü. İşaretin sağında ve solundaki değerlerin eşit olması halinde true (doğru) sonucunu gönderir.
!= Eşit değil operatörü. İşaretin sağında ve solundaki değerlerin eşit olmaması halinde true (doğru) sonucunu gönderir.
> Büyüktür operatörü. Soldaki değer, dağdaki değerden büyük ise true (doğru) sonucunu gönderir.
< Küçüktür operatörü. Soldaki değer, dağdaki değerden küçük ise true (doğru) sonucunu gönderir.
>= Büyük veya eşit operatörü. Soldaki değer, dağdaki değerden büyük veya bu değere eşit ise true (doğru) sonucunu gönderir.
<= Küçük veya eşit operatörü. Soldaki değer, dağdaki değerden küçük veya eşit ise true (doğru) sonucunu gönderir.

Daha sonra örneklerini göreceğiz; ve karşılaştırma işleminden sonra ne olduğunu, Javascript?in nasıl bir yol izlediğini ele alacağız. Şimdi sadece böyle bir karşılaştırma işleminde nasıl sonuç verdiğini görmekle yönetinelim. Düz yazı programınızda şu HTML kodunu yazın ve karsilastirma1.htm adıyla kaydedin:




Javascript?te Mukayese
<SCRIPT LANGUAGE="Javascript1.2">





<SCRIPT LANGUAGE="Javascript1.2">





Bu kod bir tarafta açıkken, oluşturduğunuz dosyayı Browser?da açın ve sonuca bakın; sonra kodunuzda x, y ve z değişkenlerinin değerini değiştirerek, Browser?a sayfayı yenilettirin; sonucun nasıl değiştiğini inceleyin. Javascript?in sonuç true (doğru) ise nasıl ilerlediğini, sonuç false (yanlış) ise nasıl ilerlediğini daha sonra ayrıntılı olarak göreceğiz. Fakat derhal öğrenmeniz gereken kuralı burada belirtelim: Javascript, karşılaştırma sonucu doğru ise, karşılaştırma komutundan sonraki ilk emri (veya emir grubunu), değilse bir sonraki emri (veya emir grubunu) icra eder. Bunun ayrıntılarını da ele alacağız. Şimdilik sadece bu kuralı bir kenara yazın!
Bu konuyu bitirmeden, bir de ne ile neyi karşılaştırabileceğinizden söz edelim. Javascript 1.0?de elmalarla (sayılarla) armutları (alfanümerik değişkenleri) karşılaştırabilir ve doğru sonucunu verebilirdi. Yani, Javascript 1.0 açısından 7 ile ?7? eşitti; Javascript önce karşılaştırılan değişkeni sayıya çevirip çeviremeyeceğine bakar; çevirebiliyorsa, karşılaştırmayı yapardı. Daha sonraki sürümlerinde durum değişti; Javascript?i tasarlayanlar bu çevirme işlemini programcıya bıraktılar; dolayısıyla Javascript elmalarla armutları ayırteder oldu!

Alfanümerik İşlemleri:

Javascript?in alfanümerik değişkenlerin değerleri ile sadece toplama işlemi yaptığını söylemiştik. Bu durumda buna toplama değil birleştirme, ekleme işlemi denir.
Aşağıdaki kodu düz yazı programınızla oluşturup, birlestir.htm adıyla kaydederseniz ve Browser?ınızda incelelerseniz, Javascript?in alfanümerik değerleri nasıl birleştirdiğini görmüş olursunuz:




Javascript?te Ekleme



<SCRIPT LANGUAGE="Javascript1.2">






Bu dosyada, iki tür yazdırma komutu kullandığımıza dikkat ediyor musunuz: ?***************ln()? ve ?***************()?. Bu iki komut arasındaki farkı bulabilir misiniz? (İpucu: ?***************()? yönteminde satırbaşı yaptırtmak için ?
? kullanıyoruz!)
Javascript, alfanümerik değerlere diğer aritmetik işlemleri yapamaz. Buna karşılık, Javascript sayılarla yaptığı bütün karşılaştırma işlemlerini alfanümerik değişkenlerle de yapar ve doğru veya yanlış sonucunu bildirir.
Daha önce kaydettiğiniz karsilastirma1.htm dosyasını düz yazı programında açın ve değişkenleri tanımladığınız bölümünü şöyle değiştirin:

x = "Ali"
y = "Ali"
z = "Veli"

Sonra bu dosyayı, karsilaştirma2.htm adıyla kaydedip, Browser?da inceleyin; değişkenlerin değerini değiştirip, yeniden inceleyin ve ne sonuç aldığınıza bakın.

Şartlı İşlemler:
Javascript?te karşılaştırma yaparken şartlı (..ise ..yap!) işlemler de yaptırabilirsiniz. Şartlı işlemlerde ? (soru işareti) ve : (iki nokta üstüste) işaretlerini kullanırsınız.
Karsilastirma2.htm dosyasının bütün ?***************..? kodlarını silin ve yerine şu iki satırı yazarak, karsilastirma3.htm adıyla kaydedin.

sonucMsg = (y==x)?"y degiskeni x degiskenine esit!" : "y degiskeni x degiskenine esit degil!"
alert(sonucMsg)

Kod dosyası düz yazı programında açıkken, karsilastirma3.htm?i Browser?da açın. Uyarı kutusunda, iki değişkenin eşit olması şarti halinde görüntülenmesini istediğiniz mesajı göreceksiniz. Dosyada değişkenlerin değerini değiştirerek, sonucu inceleyin. Bunu sağlayan şartlı işlem komutu üç bölümden oluşuyor: şartın doğru olup olmadığını sorguladığınız, soru işaretine kadar olan karşılaştırma bölümü; iki nokta üstüste işaretine kadar olan şart doğru ise uygulanacak bölüm, sonra satır sonuna kadar olan şart yanlış ise uygulanacak bölüm. Yukarıda, ?Javascript bir karşılaştırma yaptıktan sonra karşılaştırma sonucu doğru ise, karşılaştırma işleminden sonraki ilk komutu icra eder? demiştik. Burada da, x değişkeni ile y değişkeni aynı olduğu zaman, soru işaretiyle biten karşılaştırma işleminden hemen sonraki ilk komut (veya ifade) seçiliyor; değişkenler aynı olmadığı taktirde, iki nokta üstüste işaretinden sonra gelen komut (veya ifade) seçiliyor.

İşlemlerde Sıra:
Javascript?te işlemler yukarıdan aşağı ve soldan sağa yapılır, ama aritmetik işlemlerde bu kuralın bazı istisnaları vardır. Javascript kodlarınızda beklediğiniz sonuçları alamıyorsanız, önce işlemlerinizi işlem sırasına uygun yazıp yazmadığınızı kontrol edin.
Javascript?te işlemlerin genel sırası şöyledir: Atama işlemleri, şartlı işlemler, mantıksal ve/veya/değil işlemleri, karşılaştırma işlemleri, aritmetik işlemler, fonksiyonlar.
Javascript?te aritmetik işlemler ilke olarak soldan sağa doğru yapılır. Örneğin
_________________
21 Mart 2007 01:00# 3
Üyelik : 19.10.2006
Yaş : 35
Şehir : İzmir
Mesaj Sayısı : 497
Cevap : Javascript Full kod, ders ve dökümanlar
x = a * b + c

denklemi çözülürken, önce a ile b çarpılır, elde edilecek sayıya c eklenir.

Fakat bir denklemde parantez içine alınmış ifade varsa, Javascript önce parantezin içini halleder. Örneğin

x = a * (b + c)

denklemin önce b ile c toplanır, elde edilecek sayı a ile çarpılır.

Eğer bir işlemde Javascript aritmetik işlemleri sıraya sokmak zorunda kalırsa, toplama, çıkartma, çarpma ve bölme sırasıyla yapar. İşlemlerin sırası konusunda kuşkunuz varsa, mümkün olduğu kadar çok parantez kullanın.

Javascript Nesneleri
Bu noktaya kadar ele aldığımız bütün nesneler, Javascript?e HTML ve Browser tarafından sunuluyordu. Fakat Javascript, kendi kendisine nesneler de oluşturabilir. Örneğin, Javascript bir alfanümerik değişkeni ele aldığı anda bu onun için bir String nesnesi olur; ve dolayısıyla, bir değişkenden öte bazı özellikler ve metodlar kazanır. Dizi-değişkenler de oluşturuldukları anda Array nesnesi olurlar; yeni özellikleri ve metodları olur.

Program Akış Denetimi
Javascript veya bir başka programlama dili ile yazacağınız programda, zaman zaman programın akışını, programa bırakmanız gerekir. Programcı olarak siz, programın izleyeceği alternatif yolları belirlersiniz; fakat bu yollardan hangisini izleyeceğine, sizin koyduğunuz şartları değerlendirerek program kendisi karar verir. Programcılığın gerçek anlamda zevki de bu noktada başlar. Şimdi Javascript?in programın akışını kontrolde kullanacağınız unsurlarını tanımaya başlayalım.
Aşağıda yazacağımız iki Javascript kodunda Browser?a, ziyaretçinin ekranındaki bir form unsurunun içini doldurtma tekniğini kullanacağız. Henüz ele almadığımız bu tekniğin ayrıntılarını FORM nesnesinin özelliklerine değinirken ele alacağız.

If (Eğer .. ise)

Javascript programının, bir değişkenin değerine göre yönlenmesini sağlayan ilk aracı, ?if? (eğer) ifadesidir. İşte size program akışını ?if? yoluyla kontrol eden bir HTML sayfası:



Javascript?te Mukayese
<SCRIPT LANGUAGE="Javascript1.2">
function goster(secme)
{
var endeks, secilenYemek
endeks=secme.selectedIndex
secilenYemek=secme.options[endeks].text
if (secilenYemek == "Adana Kebap")
{
**********tarifForm.tarif.value=secilenYemek + " seçtiniz! Bravo!"
}
if (secilenYemek == "Yogurtlu Iskender")
{
**********tarifForm.tarif.value=secilenYemek + " seçtiniz. Sizi tebrik ederiz!"
}
if (secilenYemek == "Biber Dolma")
{
**********tarifForm.tarif.value=secilenYemek + " seçtiniz. Zevkinize hayranız!"
}
if (secilenYemek == "Yaprak Sarma")
{
**********tarifForm.tarif.value=secilenYemek + " yapması biraz zordur; ama çok lezizdir"
}
}





<FORM NAME="tarifForm">

Hangi yemeğin tarifini istiyorsunuz? Lütfen istediğiniz yemeği seçin:



Bir yemek seçiniz
Adana Kebap
Yogurtlu Iskender
Biber Dolma
Yaprak Sarma







Bu sayfayı denetim1.htm adıyla kaydedin ve Browser?inizde açın. Şimdilik, yemek tariflerini vermediğimize aldırmayın. Daha sonra bunu yapmanın yolunu da göreceğiz. Bu sayfadaki Javascript kodunda ?goster()? isimli bir fonksiyon var; bu fonksiyon kendisini harekete geçmeye çağıran nesnenin kendisine ?secme? adı altında bir takım bilgiler göndermesini şart koşuyor. Sayfamızda yer alan ve adı ?tarifForm? olan FORM nesnesi, kendi unsurlarından select nesnesindeki her değişiklikte, ?goster? fonksiyonunu harekete geçiriyor. ?yemeklistesi? isimli select etiketinin içindeki onChange (değişiklik halinde) isimli Javascript komutu, bir metod?tur ve burada kendi unsurlarını ve değerlerini topluca ?gonder? fonksiyonuna gönderecektir. (Şimdilik bu metod ve metodu kullanırken yazdığımız THIS ifadesi üzerinde durmayın. Sırası gelecek.)
Fonksiyonun başında iki değişken tanımlıyoruz: endeks ve secilenYemek. Endeks değişkeninin değeri, fonksiyona gönderilecek nesnelerden birinden alınıyor. Bu nesne ?selectedIndex? adını taşıyor. ?selectedIndex? denen şeyin, HTML belgesinin Form nesnesinin bir özelliği (property) olduğunu belirtmekle yetinelim; ayrıntılarını Form nesnesinin özelliklerini incelerken göreceğiz. Bir Form?un içinde select nesnesi varsa, Browser mevcut select ögelerini dizi-değişken yaparak 0?dan itiberen numaralar ve kullanıcının seçtiği select ögesinin numarası ?selectedIndex? adıyla bir kenara kaydeder.
Fonksiyonumuzdaki ikinci değişken olan ?secilenYemek? değişkeni de değerini, select nesnesinin seçilen ögesinin metninden alıyor. Şimdilik bu tanımlar sizin için anlam ifade etmiyorsa, üzerinde durmayın; iki değişkenimize ziyaretçinin sayfada yapacağı tercihe bağlı olarak değerler kazandırdığımızı düşünün. Şimdi dikkatimizi şu satıra verelim:

if (secilenYemek == "Adana Kebap")

Yukarıda öğrendiğimize göre, bu satırdaki ifadede Javascript?e ne demiş oluyoruz? ?Ey Javascript, ?secilenYemek? adlı değişkenin değerine bak; orada gördüğün metin, ?Adana Kebap? alfanümerik değeri ile aynı ise, bu satırdan hemen sonraki işi yap! aynı değilse, ber sonraki satıra git, oradaki işi yap!? diyoruz. Buradaki ?aynı ise? ifadesini, ?==? işaretleriyle sağladığımızı biliyorsunuz; ?hemen sonraki iş? ifadesinin de bir karşılaştırma komutu doğru sonuç verirse, Javascript?in bu karşılaştırma komutundan hemen sonra gelen satırdaki işi yapmasından kaynaklandığını hatırlıyorsunuz. Ziyaretçi ?Adana Kebap? seçeneğini seçti ise, ?Seçim, Adana Kebap ise? sorgulamasının sonucu doğru olacak, ve Javascript

**********tarifForm.tarif.value=secilenYemek + " seçtiniz! Bravo!"

komutunu icra ederek, ekrana ?secilenYemek? değişkeninin değeri yazacak ve buna ?seçtiniz! Bravo!? kelimelerini ekleyecektir. Sorgulamanın sonucu doğru değil ise, yani ziyaretçi Adana Kebap?ı seçmemişse, Javascript bir sonraki satırına atlayacaktır. Burada ?bir sonraki satır? ile şu anda içinde bulunduğumuz ?if? ifadesinin açılan ve kapanan süslü parantezle belirlenen sınırının bittiği yeri kastediyoruz. Yazma kolaylığı bakımından ve açtığımız parantezi kapattığımızdan emin olmak için süslü parantezleri ayrı satırlara yazarız. Ama bu şart değildir. Yani istese idik, burada üç satıra yayılan ?sonraki satır? aslında tek satırda yazılabilirdi.
Javascript?in, ziyaretçinin Adana Kebap?ı seçmemesi halinde atlayacağı bir sonraki satırda da bir ?if? ifadesi var. Javascript bu kez bu sorgulamanın sonucunu alacak ve bu sorgulama doğru sonuç verirse (yani ziyaretçi Yoğurtlu İskender?i seçmişse), hemen sonraki satırı, seçmemişse, bir sonraki satırı icra edecektir. Böylece dört sorgulamayı da bitiren Javascript, çalışmasına son verecektir. Taa ki, ziyaretçi, yeni bir tercih yapıncaya kadar. select etiketinin içindeki onChange (değişiklik halinde) yönlendiricisi, bu kutuda olacak her değişiklikte, formun select nesnesinin ögelerini topluca ?gosder? fonksiyonuna gönderecektir.
Bir ?if? sorgusunun içinde bir veya daha fazla ?if? bulunabilir. Böyle iç-içe ?if? ifadesi yazarsanız, her birinin icra alanının başladığı ve bittiği yeri gösteren süslü parantezlerine dikkat edin.

If ... Else (Eğer .. Diğer)
Kimi zaman bu kadar çok seçeneğe tek tek ?if? ifadesi yazmak gerekmeyen durumlar olabilir. Javascript?e ?Eğer şu değişkenin değeri şu işe şunu yap, diğer bütün durumlarda ise şunu yap!? demek istiyebilirsiniz. ?If... Else? ifadesi ile bunu sağlarız.

denetim1.?in dört ?if? ifadesini de silin ve yerine şunları yazın:
if (secilenYemek != "Adana Kebap")
{
**********tarifForm.tarif.value=secilenYemek + " tarifini veremiyoruz!"
}
else
{
**********tarifForm.tarif.value="Adana Kebap Tarifini asağıda sunuyoruz:"
}

Bu sayfayı denetim2.htm adıyla kaydedin ve Browser?inizde açın. Şimdi dikkatimizi şu satıra verelim:

if (secilenYemek != "Adana Kebap")

Yukarıda öğrendiğimize göre, bu satırdaki ifadede Javascript?e ?Ey Javascript, ?secilenYemek? adlı değişkenin değerine bak; orada gördüğün metin, ?Adana Kebap? alfanümerik değeri ile aynı değil ise, bu satırdan hemen sonraki işi yap!? demiş oluyoruz. Buradaki ?aynı değil ise? ifadesini, ?!=? işaretleriyle sağlıyoruz; ?hemen sonraki iş? ifadesinin de bir karşılaştırma komutu doğru sonuç verirse, Javascript?in bu karşılaştırma komutundan hemen sonra gelen satırdaki işi yapmasından kaynaklandığını hatırlıyorsunuz. Ziyaretçi ?Adana Kebap? seçeneğini seçmedi ise, ?Seçim, Adana Kebap değil ise? sorgulamasının sonucu doğru olacak, ve Javascript

?**********tarifForm.tarif.value=secilenYemek + " tarifini veremiyoruz!"

komutunu icra ederek, ekrana ?secilenYemek? değişkeninin değeri yazacak ve buna ?tarifini veremiyoruz!? kelimelerini ekleyecektir. Sorgulamanın sonucu doğru değil ise, yani ziyaretçi Adana Kebap?ı seçmişse, Javascript sorgulamanın sonucunun ?diğer? sınıfına girdiğini anlayacak ve ?Else? ifadesini icra edecektir. Yani ekrana ?Adana Kebap Tarifini aşağıda sunuyoruz:? yazacaktır. (Tarifi vermediğimizin üzerinde de durmayın. İlerde bu tür uzun ifadeleri Javascript ile sayfaya yazdırmanın yollarını da göreceğiz.)

Özetlersek, ?if? ifadesinde ileri sürdüğünüz şart doğru ise ilk komut dizisi, doğru değilse ?Else? bölümündeki komut dizisi icra edilir.

Program Döngü Denetimi
Javascript?te bazen işler yukarıdaki örnekte olduğu gibi açık ve belirgin şartlara bağlı ve bir kere icra edilecek türden olmayabilir. Javascript, bir işi belirli (veya kendi belirleyeceği) kere yapmasını isteyebilirsiniz. Bu tür tekrarlanan işleri Javascript?e bir kaç satırlık bir kodla yaptırtmak çoğu kez bizi sayfalar dolusu kod yazmaktan kurtarır.

?for? döngüsü
Diyelim ki, sitenizde santigrad dereceyi fahrenhayt dereceye çeviren tablo sunmak istiyorsunuz. 0?dan 100?e kadar bütün santigrad derecelerin (fahrenhayt = santigrad * 9 / 5 + 32 ) formülüyle karşılığını bulup, bir tabloya yazabilirsiniz. Hesabı yapmanın güçlüğünün yanı sıra, HTML kodunuz tam 100 adet .... kodu içerecektir. Oysa bunu iki satırlık bir Javascript kodu ile Browser?a yaptırabilirsiniz. Aşağıdaki kodu, dongu1.htm adıyla kaydedin ve Browser?ınızda açın:




Javascript?te döngü
<SCRIPT LANGUAGE="Javascript1.2">







Burada ?for? ifadesiyle tekrarlanan bir döngü oluşturuyoruz. ?for? döngüsüne geçmeden Javascript?e, sayfaya bir kaç HTML komutu göndermesini bildiriyoruz; bu komutlar sayfada bir tablo başlatıyor; tablonun birinci sırasına iki kutu oluşturarak, içlerine ?Santigrad? ve ?Fahrenhayt? yazıyor. Şimdi asıl, ?for? ifadesi üzerinde duralım:
?for? ile oluşturacağımız döngü, bir sayaca göre ilerler. Burada sayaç olarak ?santigrad? adında bir değişken oluşturuyoruz, Javascript?e ?Santigrad adında bir değişken yap, içine 0 değerini koy; ve bu değişken 100?den küçük veya 100?e eşit ise bazı işler yap!? demiş oluyoruz. Bu arada Javascript, diğer dillerin benzeri komutuna göre bize bir kolaylık sağlıyor: Javascript?in her döngü yapacağı işten sonra santigrad?ın mevcut değerine 1 eklemesini aynı satırda ve kolayca sağlıyoruz. ?for? işleminin başladığını belirten açılan süslü parantezden sonra Javascript?e her döngüde yapacağı iki işi bildiriyoruz:

fahrenhayt = santigrad * 9 / 5 + 32

Bu komutla Javascript, ?fahrenhayt? adını verdiği bir değişken oluşturuyor ve ilk değer olarak, santigrad değişkeninin değerini 9 ile çarpıp, 5?e bölüyor, bulduğu sayıya 32 ekliyor. ilk turda, santigrad değişkeninin değeri 0 olduğuna göre, fahrenhayt değişkeninin değeri 32 olarak bulunuyor; ve

Javascript ikinci işe geçiyor:

***************ln("" + santigrad + "" + fahrenhayt + "")

Bu iş ise, sayfaya bir tablo sırası ile bir tablo kutusu göndermek; bu kutunun içine santigrad değişkeninin değerini yazmak; sonra bu kutuyu kapatıp yeni bir kutu açmak; bu kutunun içine fahrenhayt değişkenini değerini yazarak, kutuyu ve tablo sırasını kapatmaktan ibaret.
Javascript, birinci turu bitirdiğinde, ?for? komutunun tayin ettiği ölçüde sayaç değişkeninin arttırıp veya azaltıp, ikinci tura başlayacaktır. Bu ne zamana kadar böyle devam edip gidecektir? Sayaç değişkeninin değeri, tayin ettiğiniz sınına ulaşıncaya kadar. Nedir bu sınır: santigrad değişkeninin değerinin 100?e eşitlenmesi. Bu kadar uzun bir tablo vermek istemiyorsanız, bu değeri istediğiniz bir sayıya indirebilirsiniz ve sayacı birer birer arttırma yerine, mesela beşer beşer attırabilirsiniz. Sayacı beşer-beşer arttırmak için ?for? komutunun son argümanını ?santigrad +=5? şeklinde yazmalısınız.

Şartlı döngü: while
Javascript kodu yazarken öyle durumlar olabilir ki, programın sayaç değişkeninin her değeri için yapmasını istediğiniz işi yapmasındansa, sadece belirli bir şart karşılanıyorsa yapmasını tercih edebilirsiniz. Bunu ?while? (...iken) ifadesiyle sağlarız. Bu yöntemle Javascript?e ?filanca işi yap, ama falanca şart varsa (veya yoksa)? demiş oluruz.
?while? ile kuracağınız döngünün şartı rolünü oynayacak değişkenin daha önceden oluşturulması, içeriğinin başka bir yöntemle belirlenmesi ve değiştirilmesi gerekir; ?for? döngüsünün aksine ?while? şartlı döngüsü bunu sizin için otomatik olarak yapmaz. Ayrıca koyduğunu şarta bağlı olarak, ?while? döngüsü sırasında yapılmasını istediğiniz iş hiç yapılmayabilir.
Diyelim ki, bir elektronik ticaret siteniz var; ve müşteri adayı ziyaretçileriniz, bazı malları Web sayfanızda toptan ısmarlayabilirler. Böyle bir siparişi alabilmek için, o maldan stokunuzda yeterli miktarda bulunması gerekir. Aşağıdaki kodu dongu2.htm adıyla kaydederseniz, ısmarlanan bir miktar üzerinden kaç sipariş karşılayabileceğini sayfanız otomatik olarak hesaplayacaktır.




Javascript?te döngü
<SCRIPT LANGUAGE="Javascript1.2">





<SCRIPT LANGUAGE="Javascript1.2">
function hesapla(miktar)
{
var endeks, talepMiktar, satis
endeks=miktar.selectedIndex
talepMiktar=miktar.options[endeks].text
satis = 0
while (talepMiktar < stok)
{
stok -= talepMiktar
satis++
}
**********miktarForm.sonuc.value=talepMiktar + " ton itibariyle "+ satis + " adet sipariş için stokumuz var!"
}





<FORM NAME="miktarForm">

Alacağınız miktarı lütfen seçiniz:



Miktarı seçiniz
100
200
300
400






Bu kodun da bir çok unsuru üzerinde durmayalım; bizi döngü açısından ilgilendiren bölümlerini ele alalım. Gördüğünüz gibi üç değişken tanımlıyoruz; ?stok? değişkeninin değerini biz veriyoruz; miktarTalep değişkeni ise sayfamızdaki Form nesnesinin ?miktar? adlı select nesnesinden alınıyor. Bu arada, işlemi yapan fonksiyonun içinde ?satıs? adlı bir değişken oluşturuyoruz ve değerinin, döngünün içinde birer birer artmasını sağlıyoruz. Bu kodun mantığı, müşterinin sipariş vereceği miktarda, stokumuzdan kaç adet toptan satış yapılacağını bilmek olduğuna göre, Javascript, döngünün içinde çalışırken şöyle düşünecektir:
?Benden, stok değişkeninin değerinden talepMiktar değişkeninin değeri kadar çıkartmam; sonra da satıs adlı değişkenin değerini bir adet arttırmam isteniyor. Ama bunu ancak ve sadece talepMiktar değişkeninin değeri stok değişkeninin değerinden az iken yapabilirim!?
Nitekim Javascript, talepMiktar değişkeninin değeri stok değişkeninin değerine eşit veya fazla hale geldiği anda, döngüye son verecek ve ?while? ifadesinin dışına çıkacaktır. Döngüden çıktığı anda Javascript?in yapacağı iş ise ekrandaki Form?un sonuc adlı kutusuna kendisine bildirilen metni yazmaktan ibaret!

do...while
?while? döngüsünün, koyduğunuz şarta göre bazen hiç icra edilmeyebileceğini söyledik. Yukarıdaki örnekte müşteri öyle bir rakam verir ki, sipariş miktarı stoktan yüksek olduğu için, hesaplama hiç yapılmaz ve müşteriye kaç parti sevkiyat yapacağımızı değil, sevkiyat yapamayacağımızı bildiririz. Fakat bazı durumlarda döngünün bir kere işlemesi, fakat ikinci ve daha sonraki seferler için bir değişkenin değerine bakması gerekebilir. Akla gelecek ilk örnek, bir elektronik ticaret sitesinde, müşteriye bir malı almak isteyip istemediği sorusudur. Bu soruyu bir kere sormak zorundayız; müşteri bu soruya ?Hayır!? yanıtını verirse, alış-veriş sorusunu soran döngüyü durdurmamız gerekir; müşteri alışverişe devam etmek istediğini bildirirse, döngü devam edecek ve müşteriye alış-veriş sorusu yeniden sorulacaktır.
Bunu, do...while (Yap ... iken) komut grubuyla yapabiliriz. Do (Yap) komutu bir kere icra edilir ve ondan sonra while (..iken) şartı aranır. Bu şart yerine geliyorsa, Do?daki komut yeniden icra edilir, şartın değişip değişmediğine yeniden bakılır.
Düz yazı programında aşağıdaki kodu yazın ve dongu5.htm adıyla kaydedin:




Javascript?te Switch
<SCRIPT LANGUAGE="Javascript1.2">







Bu programda Browser?ın kullanıcıdan bilgi alma aracı olan Prompt kutusunu kullanıyoruz; müşteri adayına ?bir? gömlek almak isteyip istemediğini soruyoruz. Buradaki ?bir? kelimesi, geçici değişkenimizden alınıyor; müşteri ikinci alış-verişini yapmaya karar verirse, bu değişkenin değerini ?Bir başka? olarak değiştiriyoruz. Bu programda, müşteri-ziyaretçinin ilk ?Evet? yanıtı halinde sayfamızda yapılabilecek siparişi alma, fiyatı bildirme, onay isteme ve benzeri işlerin hiç biri yok; Javascript sadece aynı soruyu yeniden soruyor; taa ki ziyaretci Prompt kutusuna ?Evet? dışında bir şey yazıncaya kadar. Do komutu, while bölümüne yazdığınız şart değişinceye kadar icra edilecektir. (Tabiî, buradaki örnekte bütün süreç, müşteri-ziyaretçinin Prompt kutusunda Cancel (İptal) düğmesine basmasıyla da sona erecektir; ama bu Prompt kutusunun bir özelliğidir.)

?Break? ve ?Continue?

Şartlı döngüde, tekrar eden iş, şartın yerine geldiği noktada kendiliğinden kesilecektir. Aynı otomasyonu ?for? döngüsünde break (kes) ve continue (devam et) komutlarıyla biz de sağlayabiliriz.
Javascript, Break ile karşılaştığı anda döngüyü keser ve icraata döngüden sonraki ilk ifadeden devam eder. Continue ise Javascript?in döngünün o andaki adımını durdurup, döngünün başına dönmesini sağlar; döngü baştan devam eder.
dongu1.htm adıyla kaydettiğiniz dosyada, fahrenhayt?ı hesaplattırdığınız komutla, bunu HTML belgesine yazdırdığınız komut arasına şu satırı koyarak, dosyayı, dongu3.htm adıyla saklayın.

if (santigrad == 13) continue

Browser?da incelediğinizde, Fahrenhayt derecenin 13 santigrad derece için hesaplanmadığını göreceksiniz. Eklediğiniz satırdaki ?continue? komutu, santigrad 13?e eşitlendiğinde, döngüyü olduğu yerde keserek, bir sonraki adımdan yeniden başlattı.
Eklediğiniz bu satırdaki ?continue? kelimesini ?break? diye değiştirir, dosyayı dongu4.htm adıyla kaydeder ve sayfayı Browser?da açarsanız, bu kez listenin 12?de kesildiğini göreceksiniz; çünkü break komutu döngüyü olduğu yerde durdurup, Javascript?i bir sonraki adımdan devama zorladı.




?Switch?
Javascript?in switch (değiştir) komutu, programın bir değişkenin değerine göre, belirli bir işi yapmasını sağlar. Sözgelimi, elektronik satış sitenizde, müşteri-ziyaretçiniz, alacağı gömleğin beden ölçüsünü seçecek ve siz de bu ölçüye göre, siparişi kaydedecek ve müşteriye siparişin alındığını bildireceksiniz. Javascript programının mantığı şöyle olacak: ?Müşteri büyük beden?i seçti ise Büyük bedenle ilgili işleri yap; küçük bedeni seçti ise küçük bedenle ilgili işleri yap; orta bedeni seçti ise orta bedenle ilgili işleri yap!"
Javascript?e switch komutu, bir veri kümesi gösterilerek verilir ve bu veri kümesi içinde hangi değere göre ne yapacağı case (halinde) ifadesiyle bildirilir: ?Değerin A olması halinde şu işi yap; değerin B olması halinde şu işi yap!? gibi. Şimdi şu kodu düzyazı programında yazın ve dosyayı dongu6.htm adıyla kaydedin:




Javascript?te Switch
<SCRIPT LANGUAGE="Javascript1.2">







Bu sayfayı Browser?da açtığınızda, karşınıza bir diyalog kutusu gelecektir.
Bu kutuda varsayılan değer olarak Orta Boy ölçü için O harfi bulunuyor. isterseniz, komutta değişiklik yaparak. bu kutuya istediğiniz değeri girebilirsiniz. Javascript, bu kutunun sağlayacağı değeri, ?olcu? adı altında, switch komutuna iletiyor; switch komutu da ?olcu? bilgisinin üç ayrı halinde üç ayrı yanıt veriyor. Böyle bir programı gerçek hayatta uygularken, yapılacak iş olarak sadece bir Alert kutusuyla yetinmeyerek, söz gelimi bu noktada Javascript?i farklı fonksiyonlara sevkederek, diyelim ki bir sipariş belgesi hazırlatabilirsiniz. Bu örnekte Javascript, olcu bilgisinin farklı hallerinde sadece farklı uyarı kutuları vermekle yetiniyor. Bu programda dikkatinizi çeken bir diğer nokta, her bir hale ilişkin case grubunda yer alan break komutu olmalı. Olcu isimli switch döngüsünün işi gerekli mesajı verdikten sonra bittiğine göre, Javascript?in diğer case?leri değerlendirmesini önlememiz gerekir; bunu break ile sağlıyoruz.
Ayrıca bu programda, ziyaretçi ile ilişkilerde gözönünde tutmanız gereken bir ilkenin uygulandığını görüyorsunuz: ziyaretçinin büyük beden için büyük ya da küçük harf B tuşuna basacağını bilmediğimiz için, kendimizi her iki ihtimale karşı da hazırlıyoruz. İyi bir programcılık tekniği, özellikle ziyaretçilerden girdi beklediğiniz hallerde, büyük harf-küçük harf durumlarına karşı hazırlıklı olmaktır.

Javascript?te Fonksiyon
Javascript, klasik HTML?in yapamadığı şeyler yapabilir; ziyaretçiden veya ziyaretçinin Browser programından alacağı bir bilgiyi değerlendirerek bir dizi işlem yapabilir; ziyaretçiyi sitemizde belli bir sayfaya yönlendirebilir; kısaca sayfalarımıza ziyaretçi ile etkileşme imkanı kazandırır.
Yukarıdaki çeşitli örneklerde gördüğünüz işlerin çoğu bir kere başvurulan işlerdi; fakat çoğu zaman sayfanızdaki bir Javascript işleminin defalarca yapılması gerekebilir. Hatta öyle işlemler olur ki, Javascript, başka bir işi yapmadan önce, mutlaka bu işlemi yapmak isteyebilir.
Bu tür tekrarlanan işleri, bu işin yapılması için gerekli bilgi kümesi ve komutlarla birlikte bir grup haline getirsek ve bu gruba bir isim versek; sonra bu iş kümesine ihtiyaç olduğu yerde Javascript?e ?Filanca isimli grubu al; içinde belirtilen işleri yap, sonra sonucu bu noktaya bildir!? desek; acaba işlerimiz daha kolay hale gelmez mi?
İşte bu tür, bir isim altında toplanmış işlem paketlerine Function (işlev) adı verilir; Javascript kendisine ?Şu fonksiyonu yap!? dediğiniz noktada yapmakta olduğu durdurur ve fonksiyon paketindeki işleri yapar; bu paket ortaya bir değişken veya sonuç çıkartıyorsa, o bilgiyi edinmiş olarak fonksiyon için yarım bıraktığı işleme geri döner. Fonksiyon yazmanızdaki birinci sebep, büyük bir ihtimalle, Javascript?e, Fonksiyon?un sağlayacağı bilgiyi kazandırmaktır.
__________________
21 Mart 2007 01:01# 4
Üyelik : 19.10.2006
Yaş : 35
Şehir : İzmir
Mesaj Sayısı : 497
Cevap : Javascript Full kod, ders ve dökümanlar
Genel hatlarıyla fonksiyon, şu formüle göre yazılır:

function fonksiyonun_adı (argüman1, argüman2, ... argümanN)
{
işlemler
}

Fonksiyonlar mutlaka SCRIPT etiketinin içinde yer alır. Daha sonra kullanılacak (çağrılacak) olsa da bütün fonksiyonlarınını HTML dosyasının HEAD bölümüne koymanız, Browser?ın Javascript yorumlayıcısı bakımından sürat sağlar. İyi bir programlama tekniği, bir sayfada gerekli bütün fonksiyonları, altalta, HTML?in HEAD bölümünde yer alacak bir SCRIPT etiketi içinde beyan etmek; sonra ihtiyaç olduğu yerde yeni bir SCRIPT etiketi koyarak bu fonksiyonu göreve çağırmaktır.
Bir fonksiyon, kendisini göreve çağıran komuttan veya fonksiyondan veri kümesi (argument) alabilir. Buna bir değerin fonksiyona geçirilmesi, ulaştırılması, verilmesi denilir. Bir fonksiyon, bir ya da daha fazla argüman alabilir. Fonksiyonun argümanları, bir isim altında toplanır ve bu bilgi kümesinin bölümlerine bu isimle atıfta bulunulur.

Fonksiyona değer gönderme ve değer alma
Bir fonksiyon ile Javascript programının diğer işlemlerinin ilk ilişkisi fonksiyona bir değer gönderme ve ondan bir değer almaktır. Bir fonksiyon, yaptığı işin sonucu olarak, kendisini göreve çağıran komuta veya fonksiyona kendi adıyla bir değer verebilir.
Bir örnek üzerinde düşünmeye başlayalım. Ziyaretçinizden telefon numarasını yazmasını istiyorsunuz. Ziyaretçi de sayfada bir INPUT kutusuna veya PROMPT diyalog kutusuna telefon numarasını yazıyor. Bu numarayı, sayfada başka bir programda veya bölümde kullanmadan önce, gerçekten doğru yazılıp yazılmadığını irdelemek istiyorsunuz. Ziyaretçinin verdiği telefon numarasını bir fonksiyona havale edebilirsiniz; bu fonksiyon telefon numarası arzu ettiğimiz biçimde yazılmışsa olumlu, yazılmamışsa olumsuz yanıt verebilir. Bütün yapacağımız şey, ziyaretçiden alacağımız bilgiyi, bu fonksiyona argüman olarak geçirmekten ibaret; fonksiyonun sonuç olarak verdiği değer doğru ise işleme devam edeceğiz, değilse ziyaretçiyi uyararak, doğru bilgiyi girmesini isteyeceğiz.

Şimdi düz yazı programınızda şu kodu yazıp, fonksiyon1.htm adıyla kaydedin:




Javascript?te Fonksiyon
<SCRIPT LANGUAGE="Javascript1.2">





<SCRIPT LANGUAGE = "Javascript1.2">






Bu sayfada, önce ?if(dogruMu(numara))? şeklindeki ifadeye dikkat edelim. Javascript, bu noktada ?dogruMu? fonksiyonu çağıracak, bunu yaparken de fonksiyona ?numara? adı altında bir değer geçirecektir. (Bu değeri, çeşitli şekillerde elde edebiliriz; bir Form nesnesinde INPUT kutusundan alabileceğimiz gibi, burada olduğu gibi PROMPT diyalog kutusuyla da alabiliriz.) Fonksiyondan bütün beklediğimiz ?if? sorgulamasına ?true? (doğru) veya ?false? (yanlış) şeklinde bir karşılık vermesidir. Yukarıda ?if? döngüsünü ele alırken, yanıtın doğru olması halinde ilk bölümdeki, yanlış olması halinde ?else? bölümündeki komutların uygulandığını görmüştük. Şimdi burada dogruMu() fonksiyondan ?true? sonucu dönerse, sayfaya teşekkür mesajı ve bilgi notu iki satır halinde yazılacak; ?false? sonucu dönerse, ziyaretçi numarayı doğru yazması için uyarılacaktır. (Bu örnekte program bu noktada kesiliyor, oysa gerçek hayatta bu noktada ziyaretçiye bilgi girme aracının yeniden sunulması gerekir.)
Şimdi fonksiyona dönebiliriz. dogruMu() fonksiyonu, kendisine görev verecek işlemden veya fonksiyondan mutlaka bir argüman verilmesini istiyor. ?numara? adıyla işleme sokulacak olan bu argüman, fonksiyon için bir nesnedir. Bu arada fonksiyonumuz kendi işleri için bir değişken oluşturuyor (karakter), ve içine boş değer koyuyor (null); daha sonra kendisinden beklenen değeri içine koyacağı bir değişken oluşturuyor ve içine varsayılan değer olarak ?true? kelimesini koyuyor. Aksi kanıtlanmadığı taktirde, fonksiyonu göreve çağıran ?if? döngüsüne bu değer bildirilecektir.
Fakat önce fonksiyonun gerçekten kendisine verilen bilgilerin, arzu edilen biçime uygun olup olmadığını sınaması gerekir. Bu bilgiyi tutan ?numara? nesnesi, nesne olduğu için bazı özelliklere sahiptir; bu özelliklerden biri de uzunluğudur. Önce bu uzunluğun 13 karakter olup olmadığına bakıyoruz. Ziyaretçi, telefon numarasını yazdığı halde parantezleri veya kesme çizgisini unuttuysa, verdiği bilgilerin uzunluğu 13 karakterden az olacaktır, yani ?numara.length? 13 olmayacak, ?durum? değişkenin değeri ?false? olarak değiştirilecektir. Yok, numaranın karakter sayısı 13 ise, fonksiyonumuz 13 karakteri, bir ?for? döngüsü çerçevesinde tek tek irdelemeye başlayacaktır.




charAt(i)
Fonksiyonlarda ve diğer tür işlemlerde kullanabileceğimiz bir Javascript kısaltması, ?filanca yerdeki karakter? diyebileceğimiz ?charAt(i)? ifadesidir. Burada i yerine herhangi bir rakamı yazabilirsiniz. Bu kısaltma ancak sayı ya da alfanümerik değer içeren değişkene veya nesneye uygulanabilir.
Buradaki örneğimizde, Javascript, karakter adını verdiği ve içini boş bıraktığı değişkenin değeri olarak, ?numara? nesnesinin o anda, o adımda irdelediği karakterini atamaktadır. Şimdi kendimizi Javascript?in yerine koyalım, ve buradaki ?for? döngüsünün birinci adımında ne yapacağımızı belirtelim:
?Hımm.. karakter değişkeninin değeri olarak numara nesnesinin i?nci karakterini atamam isteniyor. Peki i nedir? 0. O halde karakter, nesnenin 0 numaralı ögesi olacaktır. Nedir bu: Açılan parantez. Güzel. O halde, karakter eşittir açılan parantez. Sonra, eğer i değişkeni sıfır ve karakter açılan parantez ise devam etmeliymişim! İkisi de doğru; o halde devam. O da ne? Devam etmem gereken yerde ?continue? komutu var. Yani, işi burada kes, ?for? döngüsünün başına git ve yeniden başla diyorlar. Peki, hadi en başa dönelim. i?yi bir adet arttıralım, 2 yapalım; 2, 12 olmadığı ve 12?den küçük olduğuna göre devam edelim..?
İkinci adımda Javascript, karakter değişkeninin değeri olarak numara nesnesinin ikinci karakterini atayacak ve, i artık sıfır olmadığı için ilk continue?den geri dönmeyecek ve birinci Else?i izleyen işi yapacaktır. Bu işin ilk şartı i?nin dört olmasıdır. i bu anda 2 olduğuna göre, Javascript bu kez hiç bir ?continue?dan geri dönmeyecek ve en sondaki parseInt() işlemlerine ulaşacaktır. Ne zaman 1?nin değeri dört olursa, ikinci if?in ikinci şartı olan dördüncü karakterin kapanan parantez olup olmadığı irdelenecektir. Ziyaretçinin verdiği telefon numarasında dördüncü karakter kapanan parantez değil ise, fonksiyon kesilecek ve durum değişkeninin değeri ?false? olacak ve bu değer, fonksiyonu göreve çağıran if döngüsüne bildirilecektir. Fonksiyon aynı sorguyu, dokuzuncu karakterin kesme çizgisi olup olmadığını belirlemek için de yapacaktır.

parseInt(i,n)
Fonksiyona dikkat ederseniz, 0, 4 ve 9?ncu karakterlerdeki açılan ve kapanan parantez ve kesme çizgisi irdelemelerinde başa dönmeyen döngülerde, Javascript en sonda if ile başlayan parseInt() şeklinde bir ifadeyi icra ediyor.
Javascript, kendisine alfanümerik olarak verilen bir değişken değerini tamsayı (integer) veya kesirli sayıya (float) çevirebilir. Alfanümerik değerleri tam veya kesirli sayıya çevirmek için, parseInt ve parseFloat ifadelerini kullanırız. (Javascript?in sayı olarak verilen değişkeni alfanümerik değere (string) çevirmesi için kullanılmaya hazır bir metod yoktur; bunun için toplama işlemi içeren bir fonksiyon yazmanız gerekir.) Her iki metotta da, çevirme işleminin 10 tabanlı (decimal), 8 tabanlı (octal) veya 16 tabanlı (hexadecimal) olymasını istediğinizi, çevrilmesini istediğiniz alfanümerik değerden (veya bu değeri temsil eden değişkenin adından) sonra bir virgül koyarak, 10, 8 veya 16 rakamı ile belirtmeniz gerekir.
parseInt() metodu ile bazı çevirme işlemlerine örnek verirsek, parseInt(?123456.3333?), 123456 sonucunu verir. Çünkü bu metod kendisine verdiğiniz alfanümerik değerin içinde rakam ile artı ve eksi işaretlerinden başka bir şey gördüğü noktada durur; o noktaya kadar gördüğü unsurları bir tamsayı değişkeni olarak size geri verir.
parseFloat() metoduna da bir örnek verirsek, parseFloat(?123456.3333?), 123456.3333 sonucunu verir. Çünkü bu metod kendisine verdiğiniz alfanümerik değerin içinde rakam ile artı ve eksi işaretlerinin yanı sıra nokta işaretinden başka bir şey gördüğü noktada durur; o noktaya kadar gördüğü unsurları bir kesirli sayı değişkeni olarak size geri verir.
Her iki metod da, çevirme işlemini başarıyla yaparlarsa, kendilerini görevlendiren işleme (bizim örnekte bunu bir if döngüsü yapıyor) 1, başarıyla yapamazlarsa 0 değeri döndürürler. Yani, if döngüsü, parsInt() metodu başarılı olursa 1, başarılı olamazsa 0 sonucunu alacaktır. Biliyoruz ki, if açısından 1, true-doğru, 0 ise false-yanlış demektir.
Buradaki örnek kodda, 1, 2, 3, 5, 6, 7, 8, 10, 11, 12 ve 13?ncü karakterler, parseInt() metodu ile sayıya çevriliyor ve elde edilen sayının 0 ile 9 arasında olup olmadığına bakılıyor; sonuç doğru ise döngü bir sonraki karakteri almak üzere başa dönüyor; sonuç yanlış ise döngü o naktada break ile kesiliyor, durum değişkenin değeri ?false? yapılıyor ve fonksiyon bu sonucu kendisini görevlendiren işleme teslim ederek, kapanıyor.




Fonksiyon ile HTML unsarlarının ilişkisi
Javascript açısından, yukarıdaki gibi uzun fonksiyon ile tek satırlık bir metod?un farkı yoktur: ikisi de kendisinden beklenen bir değeri, bu değeri bekleyen işleme teslim etmek zorundadır. Bunu ister 150 satırlık komut kümesiyle yapsınlar, isterse tek satırlık bir komutla, Javascript, isteyen bütün fonksiyonlara ve metodlara kendi nesnelerini ve onların metodlarını kullanma imkanı verir; hatta bilgisayarın kaynaklarından yararlanmalarını bile sağlar.
Böylece Javascript açısından Browser ve onun görüntülediği HTML belgesinin nesne olarak özelliklerine ve bilgisayarın kaynaklarını kullanmaya biraz daha yaklaşmış oluyoruz.
Şimdi yeni bir fonksiyon yazarak, Browser?ın, bilgisayarın işletim sisteminden saat ve tarih bilgisi edinerek, Javascript?e ulaştırmasını sağlayalım. Bunun için düz yazı programınızda şu kodu yazın ve fonksiyon2.htm adıyla kaydedin.




Javascript?te Fonksiyon
<SCRIPT LANGUAGE="Javascript1.2">




<FORM method="POST" name="saatForm">
Şu anda saat:




Bu Javascript kodunda tanımladığımız değişkenin, Javascript?in otomatik bir metodundan değişken elde ettiğini görüyorsunuz.


Date(): getYear(), getMonth(), getDate(), getDay(), getTime(), getHours(), getMinutes(), getSeconds()
Bu metod, Javascript?in Browser?dan, Browser?ın işletim sisteminden, işletim sisteminin de bilgisayarın temel girdi/çıktı işlemlerini yapan (BIOS) çipinden, saati ve tarihi içeren bilgiyi almasını sağlar. Gerçi metod Date (günün tarihi) adını taşıyor, ama Date(), Javascript açısından class (sınıf) sayılır ve edinilen bilgi sadece ay, gün ve yıl bilgisini değil, o andaki saati, dakikayı ve saniyeyi de içerir.
?saat? adını verdiğimiz bu değişken, Date() metodunun sağladığı bütün bilgileri içerdiği için, içinden saate ilişkin bilgiyi söküp almamız gerekir. Date() sınıfının sağladığı bilgiyi, get... yoluyla alırız.
Burada önce biraz, hem İngilizce?den hem de Javascript dilinden Türkçe?ye tercüme yapalım:

Year: Yıl (1900?den sonra)
Month: Ay (0=Ocak - 11=Aralık)
Date: Gün (1-31)
Hours: Saat (0-23)
Minutes: Dakika (0-59)
Seconds: Saniye (0-59)
Time: Zaman (Bu bilgilerin tümü: Gün, Ayın Adı, günün tarihi, saat:dakika:saniye, Yaz saati/kış saati ve yıl)

Bu durumda getYear(), size bilgisayarın BIOS?nun ayarlı oluduğu yılı (örneğin 1999) değerini; getHours() ise bu komutun icra edildiği andaki saati (örneğin, 19) kazandıracaktır. Gördüğünüz gibi, getTime() metodu, bize olağanüstü zengin bilgi kazandırabilir.
Bizim örnek kodumuzda, ?saat? değişkeninin içinden getTime() yöntemi ile, hemen her türlü tarih ve saatle ilgili bilgi demetini alıyoruz; ve bunu bir başka metod?un işlemine tabi tutuyoruz.

toString(), toLowerCase(), toUpperCase()
Javascript?in kullanılmaya hazır işlevleri (metodları) arasında Date (Tarih) nesnesine uygulanabilecek olanlarından biri toString() metodudur. Kelime anlamı String?e çevir, alfanümerik?e çevir olan bu metodla, saat nesnesinin tamamen kendine özgü biçimi, Javascript tarafından HTML?in anlayabileceği şekle çevrilmiş olur. Buradaki örnek kodda, ?saat? değişkeninin içeriğini toString() metoduna tabi tutarak, alfanümerik değere çeviriyoruz ve bunu, HTML sayfasındaki Form nesnesinin ?saatkutusu? isimli INPUT ögesinin içeriği haline getiriyoruz.
Javascript?te, çevirme amaçlı iki metod daha vardır. toString() metodu sadece Date nesnesine uygulanabilir, ama toLowerCase() (küçük harfe çevir) ve toUpperCase() (büyük harfe çevir) metodları bütün alfanümerik değerlere uygulanabilir. Nesneleri daha ayrıntılı ele aldığımız bölümde, alfanümerik değerlere uygulanabilecek, kullanılmaya hazır fonksiyonlar diyebileceğimiz başka metodlar bulunduğunu da göreceğiz ve hepsini birarada inceleyeceğiz.




setTimeout(?fonksiyonun_adı?, milisaniye)
Örnek fonksiyonumuza dönersek; çevirme ve bulunan alfanümerik değeri HTML?in Form nesnesinin bir ögesinin içeriği olarak atama işleminden sonra, ?kronometre? adını verdiğimiz bir değişken görüyoruz; fakat bu değişkenin değeri oldukça farklı bir ifade içeriyor: setTimeout().
setTimeout(), Javascript?in 1.2 sürümüyle gelen ve kendi kendisinin zamanlamasını belirleyen bir metoddur. Buradaki örnekte, ?kronometre? değişkeninin değeri olarak, ?tarihsaat? fonksiyonumuzun, her 1000 milisaniyede bir yenilenmesini istiyoruz. Bunun sonucu, Javascript, fonksiyonu her bin milisaniyede bir çalıştıracak, ve bunun sonucu olarak HTML sayfasındaki formda saatkutusu isimli kutunun değeri sürekli yenilenecektir.
Bu metoddan yararlanarak, Javascript?e, sözgelimi her sabah 6:30?da bir iş yaptırabiliriz. Bunun için, söz gelimi setTimeout metodunu içeren değişkeni, şöyle bir döngü içine koyabiliriz:

if ((saat.getHours() == 6) && (saat.getMinutes() == 30))
{
//burada ne gibi işler yapılacaksa o işe ait komutlar olabilir, örneğin:
**********saatForm.saatkutusu.value = saat.toString()
//sonra setTimeout metodunu içeren zamanlama ifadesi gelir:
kronometre = setTimeout("tarihsaat()",10000)
}

Böyle bir döngü içine alındığı zaman kronometre sadece sabah 6:30?da saati ve tarihi gösterecektir.

Değişkenleri Değerlendirme (Eval)
Buradaki örneğimizde yer almamakla birlikte bu bölümü bitirmeden bir metoddran daha söz edelyim. Javascript?in kendi hazır fonksiyonları içinde en az kullanılanı hangisidir diye sorarlarsa Değerlendirme Fonksiyonu olan eval()?dir derseniz, yanılmamış olursunuz. Buna karşılık, Javascript?in hemen hemen en kullanışlı fonksiyonlarından biri de eval() fonksiyonudur.
Bir kere, eval(), programcıyı satırlarca kod yazmaktan kurtarır. Diyelim ki, Javascript programınızın bir yerinde

var toplamTutar = ?((siparisMiktarı * fiyatTL) * vergi)?
if (vergiYok) {
toplamTutar = ?(siparisMiktarı * fiyatTL)?
}
.......

şeklinde bir kodunuz var. Daha sonra programın herhangi bir yerinde,

***************(eval(toplamTutar))

demekle, bütün bu üç-dört satırlık kodu yazmış olursunuz. eval() sizin için değişkenlerin değerlerini bulup, sonucu değerlendirip, arzu ettiğiniz yere yazacak veya iletecektir. Bu fonksiyondan ilerde yararlanacağız.

Javascript?in Nesneleri, Olayları ve Özellikleri
Bilgisayar programcılığı da giyim-kuşam dünyası gibidir: modayı takip eder. Günümüzde programcılığın en moda unsuru Nesneye Yönelik programcılıktır dersek, gerçeği ifade etmiş oluruz.
Javascript programcılığında nesne (object), ve nesnenin özellikleri (properties), genellikle HTML belgesinin adı (name) ve değeri (value) olan herşeydir. Bir HTML unsurunun etiketinde NAME ve VALUE bölümleri varsa, bu unsur, Javascript için nesne sayılır.
Bu tanıma göre Form, Javascript için bir nesnedir. Ayrıca Form nesnesinin bir ögesi olan INPUT, kendisi de ad ve değer alabildiğine göre, Javascript için bir nesne sayılır; fakat bu nesneye daima içinde bulunduğu nesne ?dolayısıyla? atıfta bulunabilirsiniz. Bu tür atıflarda bulunurken, şu kurala uymanız gerekir:

nesneAdı.özellikAdı

Bir nesnenin durumunu, değerini veya bir özelliğini değiştiren Javascript?in kendi içinde kullanılmaya hazır işlevleri; tarih gibi, Browser?ın masaüstündeki penceresinin bir özelliği gibi değerleri belirleyen otomatik işlevleri; nesnelerin değerlerini belirli bir düzen içinde arttıran veya azaltan süreçleri; ve Javascript?in hazır şablonlarından yeni bir nesne üreten işlemleri, metod adı altında toplarız. Her nesnenin kendine ait bir metodu olabilir; bir metod birden fazla nesne ile birlikte kullanılabilir. Bu gibi ifadeleri şöyle yazarız:

nesneAdı.metodAdı (argüman)

Javascript ve niteliklerini etkilediği HTML, bir işletim sistemi ortamında, Grafik Kullanıcı Arayüzü (GUI) ile çalışan bir Browser programının içinde yer alırlar. Browser programları kendiliklerinden veya GUI sonucu, öyle bazı olaylara (örneğin Mouse işaretçisinin bir nesnenin üzerine gelmesi veya bilgisayar kullanıcısının Mouse?un veya klavyenin bir düğmesini tıklaması gibi) yol açarlar ki, bu olay işletim sistemi-GUI-Browser yoluyla HTML belgesi (ve dolayısıyla Javascript) açısından önem taşıyabilir. Bunlara Event (olay) denir, ve Javascript?e bu olayın olması halinde icra edilmek üzere özel emirler verilebilir. Bu tür komutların yazılmasında şu yöntem izlenir:

event=?fonksiyon_veya_metod (argüman)?

Aslında yukarıda özetlediğimiz üç unsuru, nesne, nesne özelliği ve Browser olaylarını buraya kadar bir çok örnekte gördük ve kullandık. Bu bölümde, bu kitapçığın elverdiği ölçüde her üçünü ayrı ayrı ve ayrıntılı ele alacağız.

Nesneler
Javascript ile yazacağımız programlar, Netscape veya Internet Explorer programlarının belge nesne modeli (Document Object Model) denen kurallar içinde hareket etmek zorundadır. Daha yüksek programlama dillerine, örneğin C++, Delphi veya Java gibi dillerle program yazmışsanız, programcı olarak başka bir programın modeli ile sınırlı olmadığınızı, hatta işletim sisteminin programlar için sağladığı arayüzle (API) kendinizi sınırlı hissetmeyebileceğinizi bilirsiniz. Fakat Javascript dahil tüm Script dilleri, Browser?ın sunduğu hiyerarşik nesne modeli ile sınırlıdır. Aşağıda Netscape?in modelini görüyorsunuz. Gerçi Internet Explorer çok daha fazla nesneyi kontrol etmenize imkan veriyor; fakat IE?nin geniş alanına giren nesnelere yönelik Javascript programı, Netscape kullanan ziyaretçilerin bilgisayarında işleyemeyebilir:
Javascript?te ?document? nesnesi kavramını öğrenirken, ilk kavranması gereken unsur, ?container? (içinde tutan, kap) meselesidir. Hatırlayacağınız gibi, yukarıdan beri Javascript?e ekrana bir şey yazdıracağımız zaman, şuna benzer bir komut veriyoruz:

***************(?

Merhaba Dünya!

?

Burada kullandığımız write()metodu, ?document? nesnesine, o da Browser?ın ?window? (pencere) nesnesine aittir. ?window? nesnesini zikretmiyoruz; çünkü zaten onun içindeyiz. Ama yeni bir Browser penceresi açtırmak istersek, bunu da açıkça belirtmemiz gerekir. Aşağıdaki kodu, düz yazı programınızda yazarak, yenipencere.htm adıyla kaydederseniz ve Browser?ınızda açarsanız, size yeni bir ?window? nesnesi oluşturma imkanı verecektir:




Javascript?te Yeni Pencere
<SCRIPT LANGUAGE = "Javascript1.2">



Bu düğmeyi tıklarsanız, yeni pencere açılır.


<FORM>





Burada ?windowNesnesi? adlı değişkinin değerine dikkat ediyor musunuz: Browser?ın kendi içinde bulunan ?window.open()? metodunu kullanarak, araç çubuğu bulunmayan, eni 300 yüksekliği 150 piksel ve ziyaretçi tarafından ölçüleri değiştirilebilen bir yeni Browser penceresi açıyor. Aslında bu noktada windowsNesnesi adlı değişken, bu nesnenin buradaki temsilcisi sayılır; yeni nesneye ne yaptırtmak isterseniz, burada, windowNesnesi değişkinini kullanarak yapabilirsiniz. Bir başka dikkat edilmesi gereken nokta, yeni Window nesnesini oluşturduktan sonra bir daha ?window? nesne adını kullanmıyoruz, sadece document adlı container?in (kabın) adına referans yapıyoruz.
Yukarıdaki şemada gördüğümüz nesnelerin HTML karşılıkları şöyledir:


Javascript Nesnesi HTML Karşılığı
Pencere (Window) Yok
Çerçeve (Frame)
Belge (Document)
Form <FORM>
Düğme
İşaretleme Kutusu
Gizli (Hidden)
Dosya Çıkart (file upload)
Parola (password)
Radyo düğmesi (Radio)
Başa dön (Reset)
Seç (select)
Gönder (Submit)
Metin (Text)
Metin Alanı (Textarea) <TEXTAREA>
Bağ (Link)
Bağlantı (Anchor)

Applet <APPLET>
Resim (Image)
Plugin <EMBED>
Alan (Area)

Bu nesneleri ve metodları ile yanıt verdikleri Window olayları (event) konusuna geçmeden önce bir iki noktayı belirtelim:

Window nesnesinin HTML karşılığı bulunmamakla birlikte BODY etiketinin onLoad ve unonLoad olaylarında işleyen bir fonksiyonla yeni window nesnesi oluşturmanız (yukarıdaki örnekte olduğu gibi) daima mümkündür. Ayrıca, içinde bulunduğunuz veya yeni açmak istediğiniz bir Browser penceresinin alt çervesindeki Status (durum) mesajı alanına istediğiniz mesajı yazdırabilirsiniz:

window.status = ?Benim sayfama hoş geldiniz!?

Internet, HTML sayfası ve bağlı belgelerle bilgisayar dosyalarını alıp vermek demektir. Mahal (Location) nesnesi, Browser?ın görüntülediği belgenin nereden geldiğini gösterir. Gerçi, HTML size görüntülediği belgenin nereden geldiğini bildirmez, ama Browser, bunu ?window.location.protocol? nesnesi olarak tutar. Bu değer ya ?http:? ya da ?file:? (ikisi de küçük harf ve sonlarında iki nokta üstüste var) olur. Örneğin:

if (window.location.protocol == ?http:? {
alert (?Bu belge Internet?ten geliyor.?) }
Else { alert (?Bu belge sabit diskten geliyor.?)}
__________________
21 Mart 2007 01:02# 5
Üyelik : 19.10.2006
Yaş : 35
Şehir : İzmir
Mesaj Sayısı : 497
Cevap : Javascript Full kod, ders ve dökümanlar
şeklinde bir kodla, belgenin mahallini araştırmak mümkündür.

Tarih (History) nesnesi ise, her iki Browser?ın, ziyaret edilen siteler ve sayfalar listesinde ileri veya geri gitmekte kullandığı nesnedir. HTML?de bu listeye erişmeyi sağlayan etiket bulunmamakla birlikte Javascript bu listeyi kullanabilir. Örneğin:

function gerigit() { window.history.go(-1) }

şeklindeki bir fonksiyon ve bu fonksiyonu çağıran bir düğme (onClick=gerigit() gibi) Tarin nesnesinden yararlanmasını sağlayabilir.




Olaylar
Browser programları, olaylı bir yaşama sahiptir! Ya bilgisayar sistemi, ya da kullanıcı (ziyaretçi), sürekli bir takım olayların (Event) oluşmasına sebep olurlar. Ya Mouse?un bir düğmesine basılır ?Click? adı verilen olay oluşur; ya klavyede bir tuşa basılır, ?KeyDown? olayı oluşur. Bir HTML sayfasının yüklenmesi biterse ?Load,? sayfadan çıkma işlemi tamamlanırsa ?unLoad? olayı olur.
Her Pencere, Browser veya Kullanıcı olayına karşılık, Javascript?in bir Olay Yönlendiricisi (Event Handler) vardır. Olay Yönlendirici, olayın adını taşır. Örneğin, kullanıcının Mouse?un bir düğmesini tıklaması, Click, bu olayı karşılayan ve yönlendiren metod ise onClick (tıklandığında, tıklama halinde) adını taşır. Javascript programcısı olarak bu olayların tümü bizi ilgilendirmediği gibi, nesnelerimiz de çoğunlukla bu olaylara ilgi göstermezler. Bizi yakından ilgilendiren nesneler ve onların olaylarla ilgisini ...... tabloda görebilirsiniz.
Event Handler?ları, bir tür adlandırılmış ama içi boş fonksiyonlar gibi düşünebilirsiniz. Programcı olarak bize düşen, bu olay karşısında olay yöndendiricisinin ne yapmasını istediğimi belirtmekten ibarettir. Event Handler?lar, daha önceden hazırladığımız bir fonksiyonu göreve çağırabilir; veya hemen oracıkta bir Javascript metodunu da devreye sokabiliriz. Mesela:



Ziyaretçi bu INPUT kutusuna soyadını yazdığında, kutunun içeriği değişmiş olacak ve bu Change (değişiklik) olayı, kendisini yöndendiren onChange sayesinde, önceden hazırladığımız ?denetle()? isimli fonksiyonu çağıracaktır. Burada gördüğünüz ?this? (bu) kelimesi, Javascript?e fonksiyonun istediği değer kümesi olarak bu nesnenin içeriğini vermesini bildiriyor. İlerde örneklerde bunu sık sık kullandığımızı göreceksiniz.

Şimdi sık kullandığımız olayları ve yönlendirilcilerini daha yakından tanıyalım:

onClick
Ziyaretçinin, Mosue işaretçisi tıklanabilir bir nesne üzerinde iken Mouse?nun düğmesine basması, Click olayını doğurur; bu olayı onClick yönlendirir. Düğmeler, işaretleme kutuları, radyo düğmeleri ve bağlantılar tıklanabilir. Olayın oluşması için varsayılan Mouse düğmesinin basılması ve bırakılması gerekir. Düğme basılı durursa, Click olayı gerçekleşmiş olmaz.
onClick yönlendiricisine, ?Click? olayı halinde ne yapmasını istediğinizi ait olduğu nesnenin HTML etiketi içinde bildirmeniz gerekir. Aşağıdaki kodu düz yazı programınızda yazar ve onClick01.htm adıyla kaydederseniz, onClick yönlendiricisi için program yazmış olacaksınız:




JavaScript?te onClick
<SCRIPT LANGUAGE="JavaScript1.2">




Düğmelerden birini tıklayınız!







Bu kodda adı geçen resim1.htm ve resim2.htm adını vereceğimiz ve iki küçük resim içeren sayfaları da oluşturalım (Elinizde hazır bir grafiğin adını verebilirsiniz).



Resim 1[veya Resim 2]



Resim 1[veya Resim 2]





Bu üç sayfayı oluşturduktan sonra onClick.htm?de sırayla her iki düğmeyi de tıklayın; her Click olayında onClick yönlendiricisinin farklı fonksiyonları çağırdığına dikkat edin.
Kimi zaman onClick yönlendiricisi, bağlantı nesnesi ile doğrudan kullanılabilir. Bağlantı nesnesi olan etiketi, bir bağlantı protokolü adresi (URL) verilmesini ister. Ancak HTTP veya FILE protokolü yerine buraya doğrudan JavaScript?in adını ve icra etmesi istenen fonksiyonu yazabilirsiniz. Örneğin, şeklinde bir ifade, protokol olarak Javascript?i göstermemizi sağlayabilir.
onClick01.htm?de INPUT etiketleri yerine, şu iki satırı yazarak, onClick02.htm adıyla kaydedip, Browser?da açın. Düğmelerin yerini bağlantılı iki kelimenin aldığını göreceksiniz; fakat sayfanın işlevi değişmeyecek. onClick, bu kez düğmenin Click olayını değil, bağlantının Click olayını karşılıyor:
Resim 1
Resim 1




onSubmit
Javascript?in, HTML?i tamamladığı noktaların başında Form ve Form yoluyla elde edilecek bilgilerle ilgili işlemler gelir. Bu işlemlerin başında ise Form?daki bilgilerin Server?a gönderilmeden önce, daha Browser?da iken doğrulanması ve hatalardan arındırılması vardır. Javascript, bunu ziyaretçinin formda, Submit (Gönder) olayına yol açan herhangi bir düğmenin tıklanması halinde yapar. Bir form, ziyaretçi tarafından türü Submit olan bir düğmenin tıklanması halinde, Browser tarafından HTTP protokolü ile Server?a gönderilir. Javascript, onSubmit yönlendiricisi ile bu olaya ilişkin işler yapabilir, fonksiyonlar icra edebilir. Fakat burada dikkat edeceğiniz nokta, ?Submit? olayına engel olmamak veya bu işlemi şarta bağladı iseniz, bu şartın yerine gelmesini sağlamaktır. Bunu bir örnek üzerinde görelim. Diyelim ki, HTML sayfanızda, şuna benzer bir FORM etiketi var:

<FORM ACTION=?form_islem.pl? METHOD=?post? onSubmit=?onayla()?>

Burada adı geçen ?onayla()? fonksiyonu HTML?in HEAD bölümünde yer alıyor ve şuna benzer komutlar içeriyor:

//onSubmit olayını yönlendirme fonksiyonu
function onayla() {
confirm(?Bu siparişi vermek istediğinizden emin misiniz??);
}

İlk bakışta böyle bir ?tuzak,? formun bir kere daha onaylandıktan sonra gönderileceğini düşündürebilir. Burada gördüğünüz ?confirm? komutu, Javascript?e, Browser?ın kullanıcıdan OK (Tamam) ve Cancel (İptal) yazılı bir kutu ile onay almasını sağlar. Kullanıcı OK düğmesini tıklarsa, Browser, Javascript?e ?true? (doğru), kullanıcı Cancel (İptal) düğmesini tıklarsa ?false? (yanlış) değeri gönderecektir; sanılabilir ki, Javascript?e ?true? değeri dönerse formu gönderilecek, fakat ?false? değeri dönerse form gitmeyecektir.
Bu doğru değil! Her iki değerde de form gidecektir; çünkü, yukarıdaki kodda Browser?ın Confirm kutusunun oluşturacağı değerin türü ile onSubmit olay yönlendiricisi arasında bir bağ kurulmuyor; başka bir deyişle onSumbit?e kendisine dönmesi gereken bir sonuç olduğu bildirilmiyor. Bunu ?return? anahtar kelimesiyle sağlarız. ?return? (anlamı: geri dön) kelimesi, bir fonksiyona kendisini göreve çağıran unsura mutlaka bir değer göndermesi gerektiğini bildirir. ?return? kelimesini kullanarak, Form etiketini şöyle yazabiliriz:

<FORM ACTION=?form_islem.pl? METHOD=?post? onSubmit=?return onayla()?>

Dolayısıyla ?onayla()? fonksiyonuna da kendisini göreve çağıran komuta bir sonuç ulaştırması gerektiğini bildtirmemiz gerekir:

//onSubmit olayını yönlendirme fonksiyonu
function onayla() {
return confirm(?Bu siparişi vermek istediğinizden emin misiniz??);
}

Bu durumda kullanıcı/ziyaretçi ?confirm? kutusunun OK (Tamam) düğmesini tıklarsa onSubmit yönlendiricisi Form?u belirtilen CGI programına, işlenmek üzere, gönderecek; Cancel (İptal) düğmesi tıklanırsa, onSubmit yönlendiricisi submit olayını durduracaktır.

onReset
Formlara koyduğunuz Reset (Başa dön) düğmesi, bir Form?daki bütün bilgilerin silinmesini sağlar; Browser?ın Geri düğmesini tıklamak dahil, hiç bir eylem ziyaretçinin yanlışlıkla bastığı Sil düğmesinin sildiğini geri getiremez. Fakat programcı olarak siz böyle bir hatayı önleyebilirsiniz. Çünkü Sil düğmesinin oluşturduğu ?reset? olayını yönlendiren onReset, size bu imkanı verir. Tıpkı onSubmit?teki gibi FORM etiketinize onReset tarafından devreye sokulacak bir doğrulama fonksiyonu koyabilirsiniz. Form etiketiniz şöyle olabilir:

<FORM ACTION=?form_islem.pl? METHOD=?post? onReset=?return sahiMi()?>

Bu fonksiyonu da HTML?in HEAD bölümünde şöyle yazabilirsiniz:
//onReset olayını yönlendirme fonksiyonu
function sahiMi() {
return confirm(?Bu formdaki büktün bilgileri silmek istediğinizden emin misiniz??);
}

Ziyaretçiniz doldurduğu formda, Gönder yerine yanlışlıkla Sil?i tıkladıysa, böylece bir şansa daha kavuşmuş olur.

onChange
HTML sayfanızda olabilecek tek değişiklik, ziyaretçinin içine bir şeyler yazabildiği veya bazı işaretler koyabildiği üç alandır: Text (Metin), Textarea (Metinalanı) ve select (Seç) etiketleri. Metin ve metinalanın içini tıklayarak Browser Penceresi?nin odak noktasını buraya getiren ziyaretçi klavyesine basarak, bu alanlara metin girebilir; bu HTML sayfasında ?change? (değişiklik) olması anlamına gelir select etiketinin sağladığı şıklardan birini seçen ziyaretçi de sayfada değişiklik olayına yol açar. ?change? olayı halinde, onChange bu olayı yönlendirir. Javascript programcısı olarak siz bu yönlendiriciye belirli bir fonksiyonu çalıştırmasını bildirebilirsiniz.
Bunu da bir örnekle ele alalım. Diyelim ki Frame (Çerçeve) esasına dayanan bir ana sayfanız var; ziyaretçinin bir çerçevedeki ?select? etiketinin seçeneklerinden birini seçmesi halinde bir diğer çerçevenin içeriği değişsin istiyorsunuz. Ana sayfanızda bir FRAMESET var ve bu üç çerçeveli bir sayfa oluşturuyor. Burada Browser?ın ?document? (sayfa) hiyerarşisi içinde Frameset ?Parent? (ebeveyn; çünkü diğer bütün Frame?leri o doğuruyor!) ve ?Frame 0? (1?nci çerçeve) ?Frame 1? (2?nci çerçeve) ve ?Frame 2? (3?ncü çerçeve) vardır. ?document? nesnesi çerçeveleri bir dizi-değişken içinde tuttuğu ve Array (dizi değişken) numaralanmaya 0?dan başladığı için çerçevelerimiz 0?dan itibaren numaralanıyor. Buna göre sağ Frame?in içeriğini değiştireceğimiz zaman bu çerçeveye "Frame 2" adıyla gönderme yapmalıyız. Frame 1?e şöyle bir FORM koyarsak, daha sonra bu formun değişiklik olayını onChange ile sağ çerçevenin içeriğini değiştirmeye yönlendirebiliriz:

<FORM METHOD="post">


Seç bakalım
Test 1
Test 2
Test 3



Burada, select nesnesinin içeriği, ziyaretçinin herhangi bir seçeneği seçmesi halinde değişmiş oluyor; bu ?change? olayı üzerine bu olayı yönlendirmek üzere kullandığımız onChange ise karşısındaki Javascript komutunu icra etmeye başlıyor. Bu uzun kodda, ?this? (bu) anahtar kelimesinin yeniden kullanıldığını görüyorsunuz. Bu kelime, herhangi bir Javascript fonksiyonuna (adı fonksiyon olmamakla birlikte burada yazdığımız kod da bir fonksiyonun görevini yapıyor) ihtiyacı olan bilgileri bu nesneden almasını bildiriyor. ?Bu? diye nitelediğimiz nesne, içinde bulunduğumuz FORM?un select ögesidir. select ögesinin OPTION?ları, bu nesnenin OPTIONS dizi-değişkeninde numaralanır ve seçilen OPTION?ın numarası ?selectedIndex,? içeriği ise ?.value? adıyla adlandırılır. Nesneleri ve özelliklerini ele aldığımız bölümde bu konuya yeniden döneceğiz.




onFocus, onBlur
Bilgisayarda bir program açıkken, Mouse ile programın başlık çubuğunu tıklayın; çubuğun renginden işletim sisteminin dikkatinin bu programın penceresinde yoğunlaştığını göreceksiniz. Bir de masaüstünde boş bir yeri tıklayın; bu pencere sistemin odak noktası olmaktan çıkacaktır. HTML sayfasında da Browser?ın Focus?unu (dikkat odağını) üzerinde topladığı veya odağın çekildiği üç nesne olabilir: Text (Metin), Textarea (Metinalanı) ve select (Seç) etiketleri. Çünkü ziyaretçinin sadece bu etiketlerin oluşturduğu nesnelere klavyenin dikkatini çekme hakkı vardır. Bu nesnelerden biri tıklanınca Browser?ın focus?u bu nesneye dönmüş, yani ?focus? olayı olmuş demektir; bu durumda, biz de bu olayı yönlendiren onFocus?u kullanabiliriz. Aynı mantıkla, ziyaretçi Browser?ın focus?unu bu nesneden başka bir yere çektiği zaman bu nesne focus?u kaybeder, ?blur? (netlikten çıkma, flulaşma) olayı olur. Bunu da onBlur ile yönlendiririz. Bu iki yönlendiricinin birlikte kullanıldığı şu örnek kodu, onFocus.htm adıyla kaydederseniz ve Browser?da ekrandaki talimatları izlerseniz, her iki yönlendiriciyi de kullanmış olacaksınız:




JavaScript?te onFocus ve onBlur
<SCRIPT LANGUAGE="JavaScript1.2">






<FORM NAME="isimForm">

Lütfen adınızı yazın ve sayfa üzerinde başka bir yeri tıklayın:


Şimdi de aşağıdaki kutuya mesleğinizi yazın:






Javascript, üstteki kutuya adınızı yazdıktan sonra başka bir yeri tıkladığınızda olan iş, ?ad? isimli metin kutusunun ?blur? olayına onBlur?ün çağırdığı goster() fonksiyonu ile; alttaki kutuyu mesleğinizi yazmak üzere tıkladığınız anda ?meslek? kutusunda olan ?focus? olayına da uyar() fonksiyonu ile karşılık veriyor.

onMouseOver, onMouseOut
Javascript dünyasında en çok kullanılan iki ?event? varsa, birincisi Mouse işaretçisinin bir nesnenin üzerine gelmesi (?MouseOver? olayı), ikincisi ise Mouse iuşaretçisinin bir nesnenin üzerinden çekilmesi (?MouseOut? olayı) sayılabilir. Bu iki olayı onMouseOver ve onMouseOut yönlendiricileri ile karşılayabiliriz. Gerçekte bu iki olayla, Mouse işaretçisi bir bağlantı satırı veya grafiğinin ve bir grafik haritasının (Map, Area) üzerine geldiği veya üzerinden çekildiği zaman ilgilenebiliriz; çünkü diğer HTML unsurları ve Javascript nesneleri ile Mouse işaretçisinin işaretleme ilişkisi yoktur.
Bu olayı ve yönlendirilmesini, şu küçük programda görebiliriz:




JavaScript?te Fonksiyon
<SCRIPT LANGUAGE="JavaScript1.2">




PC World-Türkiye



Bu kodu onMouseOver.htm adıyla kaydeder ve Mouse işaretçisini PCWORLD-TÜRKİYE bağlantısının üzerine getirirseniz, Browser?ınızın alt çerçevesindeki statü mesajı yerinde "En güzel site için burayı tıklayın!", geri çektiğinizde de "En güzel siteye gitme fırsatını kaçırdınız!" mesajını göreceksiniz.


onLoad, onUnLoad
Javascript açısından Browser?ın bir HTML sayfasını görüntülemeyi bitirmesi sayfanın ?load? (yükleme), başka bir sayfaya geçilmesi ise önceki sayfanın ?unload? (yüklenmişlikten çıkması) sayılır; ve bu iki olayı onLoad ve onUnLoad yönlendiricileri ile karşılayabiliriz. HTML dosyasının iki bölüm (HEAD ve BODY) olduğunu biliyorsunuz. Browser açısından asıl sayfa, BODY bölümüdür; HEAD bölümündeki komutlar sayfanın nasıl görüntüleneceğine ilişkin komutlar içerir.
Bir sayfa Browser?a yüklenirken yapabileceğimiz bir çok işten birisi, ziyaretçinin Browser?ının türünü yoklamak olabilir. O halde, BODY etiketini şöyle yazarsak;



ve HTML?in HEAD bölümüne bu fonksiyonu koyarsak, sayfamız yüklenirken bize ziyaretçinin Netcape mi, yoksa Internet Explorer mı kullandığını bildirebilir. Bu bilgiyi nasıl değerlendirebileceğimiz ise ayrı bir konu. ?hangiBrowser()? fonksiyonu şöyle olabilir:

// hangiBrowser fonksiyonunu tanımlayalım:
var Browser=navigator.appName + " " + navigator.appVersion;
var getkey=Browser.substring(0, 12);
function hangiBrowser()
{
if (Browser.substring(0, 8)=="Netscape")
window.location="netscape4.htm";
if (Browser.substring(0, 9)=="Microsoft")
window.location="ie.htm";
if ( (Browser.substring(0, 8)!="Netscape") && (Browser.substring(0, 9)!="Microsoft") )
window.location="belirsiz.htm";
}
// -->

Bu iki kodu içeren sayfanızı onLoad.htm adıyla kaydeder ve aynı dizine, içinde ?Netscape kullanıyorsunuz! yazılı ve adı ?netscape.htm?; içinde ?IE kullanıyorsunuz!? yazılı ve adı ?ie.htm?, ve içinde ?Ne tür Browser kullandığınızı anlamadık!? yazılı ve adı ?belirsiz.htm? olan üç HTML dosyası koyarsanız, onLoad.htm?i açmak istediğinizde kullandığınız Browser hangisi ise (onLoad.htm?in değil) diğer üç dosyadan birinin açıldığını göreceksiniz.
Bir sayfada başka bir sayfayı işaret eden bir bağlantıyı tıkladığınızda, Browser açık olan HTML kodunu silecek, yani sayfayı yüklenmemiş hale getirecektir. Bu Javascript açısından bir UnLoad olayıdır. O halde, BODY etiketimize onUnLoad yönlendiricisini harekete geçiren bir fonksiyonu çağırmasını söyleyebiliriz.
Aşağıdaki HTML konudu onUnLoad.htm, ve bir HTML sayfasına da sadece ?Güle Güle.. Yine Bekleriz!? yazarak, gulegule.htm adıyla kaydederseniz sayfanız kapanırken ziyaretçinize veda etme imkanınız olur. (Ama çoğu ziyaretçinin bundan hoşlanmayacağına emin olabilirsiniz!)




JavaScript?te onUnLoad
<SCRIPT LANGUAGE="JavaScript1.2">




Bu sayfa size güle güle diyecek!!
Baska sayfa


Buradaki BODY etiketi, Browser başka sayfaya geçmek üzere mevcut sayfayı sildiği anda, Browser?a yeni bir pencere açarak, bu pencerede gulegule.htm?i görüntülemesini sağlayacaktır.

onError, onAbort
Ziyaretçinin Browser?ı açmak üzere olduğu sayfayı transfer hatası yüzünden açamaz, HTML veya Javascript kodunu doğru yorumlayamazsa, Error (hata) olayı oluşur. Javascript, sadece kendisine ilişkin hata durumlarını onError ile yakalayabilir.
Javascript?in Browser penceresiyle ilgili hatasını yakalamak istediğiniz kod, HTML?in HEAD bölümünde, SCRIPT etiketleri içinde ve ?window.onerror? kelimeleri küçük harfle yazılmış olarak bulunmalıdır:

window.onerror=hataHalinde()
function hataHalinde (message, url, lineNumber)
{
messageList = new Array()
urlList = new Array()
lineNumberList = new Array()
messageList[messageList.length] = message
urlList[urlList.length] = url
lineNumberList[lineNumberList.length] = lineNumber
alert(messageList[0] +
"
dosya adı " + urlList[0] +
"
satır sayisi " + lineNumberList[0])
return true
}

Bu kodu üzerinde çalıştığınız Javascript kodu içeren bir HTML sayfasına yerleştirdiğiniz taktirde olabilecek hatalar bir Uyarı kutusuyla size bildirilir. Sayfanın ve Javascript?in hatasız çalıştığını anladıktan sonra bu kodu kaldırabilirsiniz.
Javascript, sayfalarınızdaki grafik unsurların da hata halini yakalayabilir. HTTP iletişiminde, en sık görülen transfer hatası grafik unsurların aktarılması sırasında olur; ayrıca HTML tasarımı sırasında grafik dosyalarının sayfaya veya sitenin kök dizinine göre göreli adresinin yazılmasında sık yapılan hatalar, grafik unsurların aktarılmasını engeller. Bu tür hatalarda ziyaretçinizi şu Javascript koduyla uyararabilirsiniz:



Sayfalarınıza koyduğunuz grafik unsurlar ziyaretçilerinizin sabrını taşırır da, grafiklerin sonuna kadar aktarılmasını beklemeden Browser?ın Stop düğmesini tıklarlarsa, bunun sayfanız için kötü sonuçları olabilir. Grafik unsurlara bağlantı belirten alan haritaları (AREA, MAP) etiketleri koymuş olabilirsiniz. Ziyaretçinin Browser?ının Stop düğmesini tıklaması, Javascript açısından abort (yarıda kes) olayının doğması demektir; bunu onAbort ile yönlendirebilirsiniz. Bu yönlendiriciden yararlanarak ziyaretçiye sayfanın eksik olduğunu bildirmeniz yerinde olur. Bunun için IMG etiketini şöyle yazabilirsiniz:



Nesneler ve Olayları Birleştirelim
Şimdi Javascript açısından Browser nesnelerinin neler olduğunu biliyoruz; Browser?ın Javascript açısından ne gibi olaylar oluşturduğunu ve bu olayları nasıl kullandığımızı küçük örneklerle gördük. Olaylardan yararlanarak Javascript?le nesneleri etkileyen programlar yazabiliriz; fakat bunun için nesnelerin ne gibi özellikleri olduğunu ve bunları nasıl etkileyebileceğimizi de bilmemiz gerekir. Bu bölümde nesnelerin Javascript ile etkilenebilir özelliklerinin neler olduğunu ele alacağız.
Nesnelerin ayrıntılarına girmeden önce bir noktaya açıklık getirelim: Javascript ile bir HTML unsurunu etkileyebilmek, örneğin bir çerçevenin (Frame) içeriğini değiştirebilmek için mutlaka o nesnenin bir olaya karşılık verir olması gerekmez. Çerçeveler HTML etiketleri ile şekillenirler; herhangi bir olaya karşılık vermezler. Dolayısıyla olaylara yanıt vermeyen nesneleri, olaylara yanıt veren nesneler yoluyla etkileyebiliriz; bunun için de bir çok HTML nesnesinin özellikleri bilmemiz gerekir.
Bu açıdan bakınca, olaylara yanıt versin-vermesin, HTML nesnelerimizi, Browser Nesneleri, Belge Nesneleri, Form Nesneleri ve Javascript Dil nesneleri olarak dört ana gruba ayıracağız.

Browser Nesneleri
Browser?ın Javascript dilinde adı Navigator?dır. Ziyaretçinin Browser programı ister Netscape Navigator olsun, isten Internet Explorer olsun, Javascript için Navigator?dır; nesnelerine de Navigator Nesneleri denir. Bunların başında, Browser?ın pencereleri ve Çerçeveler gelir.

Pencere (window)
Şu ana kadar yazdığımız bir çok Javascript kodunda Navigator penceresinin bazı özelliklerini kullandık: width (genişlik), height (yükseklik), toolbar (araç çubuğu) gibi. Şimdi bu özellikleri toplu olarak sıralayalım:

width Navigator?ın sayfanın görüntülenmesi için ekrandaki temiz alanının piksel olarak genişliği.
height Navigator?ın sayfanın görüntülenmesi için ekrandaki temiz alanının piksel olarak yüksekliği.
toolbar Navigator?ın araç çubuğunun gösterilmesi (=1) veya gizlenmesi (=0).
menubar Navigator?ın menü çubuğunun gösterilmesi (=1) veya gizlenmesi (=0).
scrollbars Navigator?ın sağ ve alt kenardaki kaydırma çubuklarının gösterilmesi (=1) veya gizlenmesi (=0).
resizable Navigator penceresinin büyütülebilir-küçültülebilir olması (=1) veya olmaması (=0).
status Navigator penceresinin alt kenarındaki mesaj çubuğunun gösterilmesi (=1) veya gizlenmesi (=0).
location Navigator penceresinin URL adres çubunun gösterilmesi (=1) veya gizlenmesi (=0).
directories Netscape?de ikinci araç çubunun gösterilmesi (=1) veya gizlenmesi (=0).
copyhistory Mevcut Navigator penceresinin history kaydının (daha önce ziyaret edilen URl adreslerinin tutulduğu çizelgenin) yeni pencereye de kopyalanması.
outerWidth Navigator penceresinin piksel olarak genişliği.
outerHeight Navigator penceresinin piksel olarak yüksekliği.
left Navigator penceresinin ekranın sol kenarından piksel olarak uzaklığı.
top Navigator penceresinin ekranın üst kenarından piksel olarak uzaklığı.
alwaysRaised Navigator penceresinin masaüstünde açık bütün pencerelerin üzerinde kalmasını sağlar. (Sadece Windows ve MacOS?de işler.)
z-lock Navigator penceresinin içi tıklansa bile masaüstünde açık bütün pencerelerin altında kalmasını sağlar. (Sadece Windows ve MacOS?de işler.)

(Evet-Hayır anlamına değer alan özellikleri 1 ve 0 ile belirtebileceğiniz gibi yes (evet) ve no (hayır) ile de belirtebilirsiniz.)

Javascript?in yeni Navigator penceresi açma metodu, window.open() şeklinde yazılır:

yeniPencere = window.open(?yenisayfa.htm?, ?YeniPencereninAdı?, ?toolbar=1, menubar=yes, resizable=no?)

Burada, yeni pencereye vermek istediğiniz adın tek kelime olduğuna, özelliklerin bir çift-tırnak içinde toplandığına dikkat edin.
Navigator pencereleri, xxxx.close() metodu ile kapatılır. xxxx yerine açık pencerenin adını yazmanız gerekir. Aksi taktirde Javascript komutunu icra ettiğiniz pencerenin kendisi (yani Browser) kapanır. (Bazı Browser?ların bazı sürümleri Javascript tarafından açılmamış Navigator pencerelerinin Javascript ile kapatılmasına izin vermezler.)
Bu nesnenin ve her iki metodun da kullanımını daha önce gördük. Mevcut bir HTML belgesinin adını vermeden, yeni pencereyi açtırıp, içine Belge nesnesini kullanarak HTML komutları yazdırmayı, aşağıda Belge Nesnesi bölümünde ele alacağız.
Bu arada, Browser?ın kendisinin bazı özellikleri ile Javascript açısından nesne olduğunu tekrarlayalım. Bu açıdan Browser?ın Javascript için şu özellikleri vardır:

appname Browser?ın adı
appVersion Browser?ın sürümü
appCodeName Browser?ın kod adı
userAgent Browser?ın Server?a kendisini tanıtırken verdiği isim.

Şu kısa kodu browser.htm adıyla kaydeder ve farklı Browser?larla açarsanız, Netscape ve IE hakkında bilgileri bir kutu içinde görebilirsiniz:



<SCRIPT LANGUAGE = "JavaScript">
function siziTaniyalim () {
var BrowserAdi = ""
BrowserAdi += "Browser: " + navigator.appName + "
"
BrowserAdi += "Sürümü:" + navigator.appVersion + "
"
BrowserAdi += "Kod Adı: " + navigator.appCodeName + "
"
BrowserAdı += "userAgent: " + navigator.userAgent + "
"
alert(BrowserAdi)
}


Browser?ınızı Tanıyor Musunuz?


<FORM>





Mesaj Kutuları
Navigator penceresi, üç tür mesaj kutusu açabilir. Bunlar basit bilgi verme kutusu (alert), doğrulama kutusu (confirm) ve kullanıcının bilgi girme kutusudur (prompt).
Bunların genel yazım kuralı şöyledir:

window.alert(mesaj)
return window.confirm(mesaj)
return window.prompt(mesaj, varsayılanCevap)

Bu üç kutunun çeşitli kullanım şeklini, başka vesilelerle, daha önceki örneklerde gördük.

Çerçeve Nesnesi
Bir Navigator penceresinde birden fazla HTML belgesi görüntüleme imkanı veren çerçeve (Frame) tekniği, tasarım açısından kolaylık sağlar. Bununla birlikte halâ bazı Web ziyaretçilerinin çerçeveden hoşlanmadıkları da gerçektir.
Çerçevelerin, Navigator açısından nasıl bir hiyerarşı işlediğini daha önce gördük. Javascript açısından her bir çerçeve bir pencere sayılır; bunlara atıfta bulunurken şu adlandırma uygulanır:

top En üst pencere. yani Browser?ın kendisi.
parent Herhangi bir Frame?i oluşturan Frameset. Çerçeve çerçeve içinde ise, bir çerçevenin içinde bulunduğu çerçeve parent sayılır. Sayfada bir Frameset varsa, bütün çerçeveler için ?top? aynı zamanda ?parent? sayılır.
self Çerçevenin kendisi.

Daha önce de belirttiğimiz gibi, Javascript, bir parent (ebeveyn) Frameset?in yavru çerçevelerini 0?dan itibaren numaralar. Yani, sayfanızda iki çerçeveniz varsa, birincisi ?parent.frames[0]? ikincisi ise ?parent.frames[1]? adıyla bilinir. Herhangi bir çerçevenin içeriğini dinamik biçimde belirlemenin bir örneğini yukarıda gördük. Burada write() metodunu kullanarak, aynı işi nasıl yapabileceğimizi ele alalım.
__________________
06 Nisan 2007 05:02# 6
Üyelik : 6.04.2007
Yaş : 37
Şehir : Ankara
Mesaj Sayısı : 84
Cevap : Javascript Full kod, ders ve dökümanlar
Paylaşım için teşekkürler güsel bi anlatım olmuş
25 Nisan 2007 01:36# 7
Üyelik : 19.10.2006
Yaş : 35
Şehir : İzmir
Mesaj Sayısı : 497
Cevap : Javascript Full kod, ders ve dökümanlar
sağolasın..teşekkürler...

Konu Bilgileri

Konuyu şu anda 1 kişi okuyor ( 0 kayıtlı ve 1 ziyaretçi ) .
makineteknik.com 'da yer alan üyelerin oluşturduğu tüm içeriklerin doğruluğu ve yayınlanması ile ilgili yasal yükümlülükler içeriği oluşturan üyeye aittir. Bu içeriğin, görüş ve bilgilerin yanlışlık, eksiklik veya yasalarla düzenlenmiş kurallara aykırılığından makineteknik.com hiçbir şekilde sorumlu değildir. Sorularınız için içerik sahibi ile irtibata geçebilirsiniz.
b