published on 03.07.2018

Bu yazıda, liquid syntax’ı ile diziler üzerinde yapılabilecek bazı işlemler üzerinde duracağım. Etiketlere Göre İlgili Yazılar Devam konusundaki inadım üzerine liquid’in array yapısı ile epey içli dışlı oldum. Öğrendiklerimi burada not alacağım.

Boş Dizi Nasıl Tanımlanır ?

Doğru cevap: “Tanımlanamaz!” Öyle bir yol yok. Mesela, C#‘da List<int> mylist = new List<int>();. Boş bir liste oluşturduk az önce. Liquid syntax’ında hilelere başvurmak zorundasınız.

1
{% assign list = '' | split: '' %}

Belli Bir Indexe Yeni Değer Nasıl Atanır ?

1
{% assign list[index] = value %}

index yerine değeri eklemek istediğiniz index, value yerine de değeri yazın.

Keşke! Ne yazık ki böyle bir yol yok. Bir dizinin belli bir indexine yeni bir değer atayamazsınız. Diziyi tamamen yeniden oluşturmalısınız.

Diziye Yeni Değer Nasıl Eklenir ?

Ekleyemezsiniz. Tek çareniz concat fonksiyonu ki o da yalnızca array ile arrayi birleştirir. Yani yine bir hileye başvurmalıyız.

Önce, atayacağımız değeri tek elemanlı bir arraye çeviririz. Tıpkı başta boş dizi tanımladığımız gibi.

1
2
{% assign value = "my_very_special_value" | split: 'ğçş' %}
{% assign list = list | concat: value %}

Neden sadece split: '' değil de split: 'ğçş'. Çünkü ilk yöntem değeri karakter bazında böler. Mesela Mert |split: '', ['M', 'e', 'r', 't'] şeklinde 4 elemanlı dizi oluşturur. split: ',' Virgüllere göre böler. ‘ğçş’ art arda gelme ihtimali olmadığı için, bir elemanlı dizi, yani tekrar aynı değeri elde edeceğiz.

Eğer bu şekilde kukla split kullanmazsak, concat fonksiyonu yalnızca arrayler için geçerli olduğunu söyleyen bir hata verecektir.

Bir Diziyi Başka Bir Diziye Göre Sıralamak

Teknik anlamda kolay olması gereken bu olay, burada imkansıza yakındır. Aklıma ilk gelen yapı, dictionary olmuştu. Tabii ki aradığımı bulamadım. Daha sonra kendi 2 boyutlu arrayimi oluşturayım dedim. Yine mümkün olmadığını gördüm. İki ayrı array’i aynı döngü içinde döndürmekten başka çare ne yazık ki bulamadım.

2 Boyutlu Diziler

Her ne kadar direkt iki boyutlu dizi tanımlayamasak da mevcut bir yapıya aşağıdaki gibi ulaşabiliriz.

1
{% assign x = site['collection_name'][0].title %}

'collection_name' adındaki koleksiyonun 0. elamanının title değeri x değişkenine atanmıştır. Benzer şekilde, kendi .yaml dosyamızı oluşturup orada multi-dimensional yapılar tanımlayıp çağırabiliriz.

En Küçük Değeri Elde Etmek

1
2
{% assign my_array =  "1,2,3,4,0,1,-5,8" | split: "," %}
{% assign min_val =  my_array | sort | first %}

min_val = -5 olacak şekilde atanmıştır.

Dizi[i]‘yi myVal ile Kıyaslamak

1
2
3
4
5
6
7
8
9
{% assign myVal = 10 %}
{% assign my_array =  "1,2,3,4,0,1,-5,8" | split: "," %}

{% for arrayVal in my_array %}

    {% if arrayVal > myVal %}
        // Do something here...
    {% endif %}
{% endfor %}

Kod sadece bir örnek, eğer array’deki değer daha büyükse if içinde bir şeyler yapacağız. Burada dikkat edilmesi gereken arrayVal’ın integer olmamasıdır. string ile integerı kıyaslayamayacağımıza dair bir hata alırız. Çözümü kolay. If statementtan hemen önce arrayVal’ı integer’a çevirmeliyiz.

1
{% assign arrayVal = arrayVal | times: 1 %}

Eğer float’a çevirmek istiyorsak 1.0 ile çarpmalıyız. Float’a ya da integer’a çevirmemiz bölme işleminde fark yaratacaktır. Eğer float’a çevirirsek float bölüm 1.0/4 = 0.25, integer’a çevirirsek integer bölüm 1/4 = 0 elde ederiz.

You are reading the 9th of 19 episodes in Jekyll.
Published on 03.07.2018 by Mert Bakır with commit 7858b9b.
jekyll
#jekyll #liquid #web-dev
Next episode:
Pagination Filtered by Category
published on 18.05.2018

Pagination. Sayfalandırma. İsteğimiz her post için ‘önceki’ ve ‘sonraki’ postlara gidecek birer link oluşturmak ve bunu herhangi bir plugin kullanmadan yapmak. Aslında, postları tarihe göre sıralayıp önceki ve sonraki postlar için birer link ekleyeceğiz. Olduça basit bir iş. …

published on 01.07.2018

Oldukça uzun, bir o kadar da gerekliliği tartışılır kod parçasını paylaşmak üzereyim. Baştan söyleyelim, biraz döngüler dönecek if statementlar kontrol edilecek. Bunlara bağlı olarak, eğer blogunuzda çok post varsa build time kötü derecede etkilenecek. Ne kadar etkisi olur, 11 postluk blogta şu an …

published on 03.07.2018

Bu yazıda daha önce yazdığım Etiketlere Göre İlgili Yazılar konusundaki yapıyı eleştirip iyileştireceğiz. En azından başlangınçta öyle düşünüyordum. Kısaca hatırlayalım, ne yaptığımızı: […] Amaç: Tüm postlar arasından (all_posts) mevcut sayfanın etiketlerinden (page.tags) en az birine sahip …

published on 21.08.2020

Hugo için rss-feed-in-hugo yazısını paylaştıktan sonra fark ettim ki jekyll için yazmamışım. İki yol göstereceğim, birincisi eklenti ile ikincisi liquid kodu ile. […] Eklenti ile yapmak oldukça kolay. Gemfile’ınıza gem 'jekyll-feed' satırını ekleyin ve _config.yml dosyasına ise …

published on 20.01.2019

Bir postun altına, sıradaki N adet postun linkini nasıl ekleriz? Pagination, ama previous ile next yerine next N post. N, sizin seçeceğiniz bir sayı. Pagination adlı yazıda, önceki ve sonraki yazıları nasıl elde edeceğimizi anlatmıştım. Bir de uzunca ve build time kötü etkileyecek ama teoride …

published on 03.07.2018

Bu yazıda liquid syntaxında forloop’dan bahsedeceğiz. Yeni başlayanların da ilk karşılaştıkları klasik yapı, for döngüsü. […] 1 2 3 {% for post in site.posts%} // Do something here {% endfor %} Hemen karşınıza çıkmayan bazı incelikleri var. Onları paylaşalım: […] 1 2 3 {% for …