Ana içeriğe atla

Document Object Model (DOM)

DOM Document Object Model kelimesinin kısaltılmasından gelir ve Türkçe karşılığı Belge Nesne Modelidir.
DOM, HTML, XML gibi belgelerin diğer programlama dilleri veya script dilleriyle iletişim kurabilmesini sağlamak için geliştirilmiş bir arabirimdir.
Programlama dillerinde sıkça karşımıza çıkan Object Oriented yaklaşımı da bu yapıya benzerdir. Object Oriented yaklaşımında kullandığımız nesneler yada sınıflar, DOM yapısına göre bir HTML sayfası içerisinde bulunan etiketleri (tag) kapsar.
HTML sayfasında bulunan <head>, <body>, <h1>, <img> gibi etiketler birer DOM nesneleridir.
DOM sayesinde HTML veya XML elemanları ile programlama veya script dilleri arasında haberleşme sağlayarak daha etkileşimli web siteler yapılabilmesini sağlanır.
DOM, Javascript, PHP, ASP, Java vb. birçok dile destek verir.
DOM'daki nesneye ulaşmak için 4 yol var:
  • getElementById
Sadece bir elementi getirir. O da id sini belirttiğiniz elementtir.
document.getElementById("id of the element")
  • getElementsByName
İsmi aynı olan element kümesini getirir. İstediğiniz element için index belirtmeniz gerekir. İndex 0 dan başlar.
document.getElementsByName("name")[index]
  • dom:name (applies only to elements within a named form)
Bu yöntem sadece web sayfasında ismi olan formdaki elemente uygulanır. 
document.forms["name of the form"].elements["name of the element"]
name of the form: ulaşmak istediğiniz elementin bulunduğu formun adı

Html Kodu<form name = "home"   ...       ...           ...              <input type ="text" ... name="userName"...</form>

Selenium Kodudocument.forms[home].elements["userName"]
  • dom:index
Ulaşmak istediğiniz elementin bulunduğu formun adı olmak zorunda değil çünkü index ile erişim sağlıyorsunuz. İndex 0 'dan başlıyor.
document.forms[index of the form].elements[index of the element]index of the form: elementin bulunduğu formun indexi

Html Kodu:<form action...    ....       <input ...             .........                  ..........             <input size ="15" name ="phone"....</input>

Selenium Kodu:document.forms[0].elements[3]Web sayfasında tek form olduğu için formun indexi 0, aradığımız element "phone" formdaki 3. input olduğu için indexi 3.
x

Yorumlar

Bu blogdaki popüler yayınlar

Selenium - XPath Kodları

XPath, XML Path Absolute XPath: root node u verir ve / ile başlar Elementin path inde herhangi bir değişiklik yapılırsa, test kodu hata verir. Örn:  html/body/div[1]/section/div[1]/div/div/div/div[1]/div/div/div/div/div[3]/div[1]/div/h4[1]/b Relative XPath: xml dokümanındaki elementi verir ve // ile başlar Örn : //*[@class='featured-box']//*[text()='Testing'] XPath Kombinasyonları: Belli bir tagin belli bir attribute değeri ile kullanımı Herhangi bir tag in belli bir attribute değeri ile kullanımı "and" operatörü "or" operatörü Belirli bir değer ile başlayan attribute Metnin bir kısmını içeren attribute Sadece text() Herhangi bir attribute un değeri Belli Bir Tag'ın Belli Bir Attribute Değeri ile Kullanımı (Specific tag with specific attribute value) Html Kodu < input   id = "Lid"  .....   > input:tag adı (etiket adı) id : attribute Lid : attribute değeri Selenium Kodu driver.findElement(By.x...

Otomasyon Testlerini JUnit ile Önceliklendirme

Kullandığınız IDE'de ilk olarak çalışmasını istediğiniz kodun @Test annotation'ının üstüne  @Category({Critical.class}) yazın. İkinci olarak çalışmasını istediğinizin üzerine; @Category({Major.class}) yazın. Bu categoriler için Critical ve Major interfacelerini oluşturun. Critical interface inin içine import org.junit.experimental.categories.Categories; import org.junit.runner.RunWith; @RunWith(Categories.class) @Categories.IncludeCategory({Critical.class}) public interface Critical { } Major categorisinin içine import org.junit.experimental.categories.Categories; import org.junit.runner.RunWith; @RunWith(Categories.class) @Categories.IncludeCategory({Major.class}) public interface Major { } yazın. pom.xml'e <profiles>             <profile>                 <id> All </id>                 <build> ...