Bir Şarkı Sözü XML'i ve Bu XML'in HTML'e Çevrilmesi
Giriş
Bu örnekte şarkı sözlerini saklamak için bir XML dili yaratıyoruz. Örnek olarak bir şarkı sözünü yazıyoruz. Bu şarkı sözünü XSL ile HTML'e çeviriyoruz.
Aşağıda "Nedir Bu Başımda Bu Sevda" adlı şarkı sözünün XML'i bulunmaktadır.
1 <?xml version="1.0" encoding="ISO-8859-9"> 2 <swl> 3 <song id="1"> 4 <name>Nedir Bu Başımda Bu Sevda</name> 5 <composer>Neşet Ertaş</composer> 6 <word>Neşet Ertaş</word> 7 <songword> 8 <portion> 9 <line>nedir bu başımda bu sevda nedir</line> 10 <line>yandım ataşına yar ben kaç senedir</line> 11 <line>sevdiğim derdime derman sendedir</line> 12 <line>derdimin dermanını ver de öyle git</line> 13 </portion> 14 <portion> 15 <line>gönül mecnun olmuş çölde geziyor</line> 16 <line>halim kalem olmuş kara yazıyor</line> 17 <line>gün geçtikçe yarelerim azıyor</line> 18 <line>mevlayı seversen sar da öyle git</line> 19 </portion> 20 <portion> 21 <line>bülbül gibi ahım kaldı güllerde</line> 22 <line>baykuş gibi öttüm viran yerlerde</line> 23 <line>bir garibim kaldım gurbet ellerde</line> 24 <line>perişan halimi sorda öyle git</line> 25 </portion> 26 </songword> 27 </song> 28 </swl>
Bu dökümanın root elementi swl(song word language)'dir. Görüldüğü gibi song element'inin içinde şarkının adı(name), Bestecisi (composer) ve Söz Yazarı (word) bilgisi verilmiştir. songword element'i ile şarkının sözlerini veriyoruz. portion kıta line ile satırlar verilmektedir. XML'imizi yazdıktan sonra bu XML'i HTML'e çeviren bir XSL yazmamız gereklidir. Aşağıda bu XSL'in kodu görülmektedir.
Üç tane tamplate bulunmaktadır. İlk tamplate match ile /(root) element'ini yakalamaktadır. Bizim XML elementimizde root element'i swg'dir. Diğer iki tamplate ise name ile yaratılmış tamplate'lerdir ve istediğimiz zaman çağrılmaktadır. root element'ini yakaladıktan sonra HTML kodlarını yazmaya başlıyoruz. Şarkının adı'nı h3 başlığı içine alıyoruz. XSL'de bir element'in değeri <xsl:value-of select="elementadı"/> ile alınmaktadır. XSL'de görüldüğü gibi name lement'inin değeri h3 element'i içine konulmuştur. name element'ine erişmek için /swl/song/name şeklinde bir yol verilmiştir. Bu swl'in içinde song element'in içinde name element'i anlamına gelmektedir. Bir element'e veya attribute'ye ulaşmak için XPATH denilen adresleme sistemi kullanılır.
Şarkının adını başlığa koyduktan sonra şarkı sözlerini almamız gerekiyor. Fakat birden fazla portion ve line olduğu için döngü açmamız gerekli. Bunun için XSL'de xsl:for-each element'i kullanılır. Biz /swl/song/songword/portion ile partion için hem de line ile line için döngü açıyoruz.Dikkat edilirse poriton'lara /swl/song/songword/portion şeklinde eriştikten sonra line'lara erişmek için sadece line ismini kullandık. Çünkü portion seçilmiş olduğu için /swl/song/songword/portion ifadesi tekrar yazmamıza gerek yok. portion element'i seçilmemiş olsaydı line element'lerini seçmek için /swl/song/songword/portion/line kullanacaktık. Her portion'da araya iki satır koyuyoruz. Böylece satırlar arasında biraz boşluk oluyor. Bir satır seçildiğinde tablecell adlı tamplate çağrılmaktadır. Bu tamplate her satır için bir satır ve hücre koymaktadır. Satırın değeri bu hücreye yazılır. Böylece her yeni line element'i için yeni tr element'i yaratılmış olur. Tüm portion ve line'lar bittikten sonra, tablonun en altına besteci ve söz yazarı adını koyuyoruz. fieldtablecell tamplate'ti parametre olrak aldığı field ve value değerlerini uygun bir şekilde bir tablo satırı yaratmaktadır. Bu tamplate hem besteci-isim hem de söz yazarı-isim çiftleri için kullanılmıştır.