Vue.js Koşullar ve Döngüler
Vue.js Koşullar ve Döngüler |
Vue içerisindeki Koşulları ve Döngüleri anlatmaya çalışacağım. Daha önce direktiflerden bahsetmiştim. Şimdi bu iki özellik de birer direktif olarak çalışmakta. Ancak bunlar Vue içerisinde tanımlanmış direktiflerdir.
Koşullar
İf direktifini inceleyelim.
Vue JS
var uygulama = new Vue(
{
el: '#icerik',
data: {
goster: true
}
})
HTML
<div id="icerik">
<span v-if="goster">Görüntüleniyor</span>
</div>
Yukarıdaki "v-if" örneği:
En basit kullanımı budur. Peki devamını getirelim, yani else, else if kullanalım.
HTML
<div id="icerik">
<span v-if="goster == 1">Deger: 1</span>
<span v-else-if="goster == 2">Deger: 2</span>
<span v-else">Ne 1, ne de 2</span>
</div>
Döngüler
Döngüleri gösterelim. Uygulama içerisinde bir dizi tanımlayalım ve içerisindeki verileri HTML etiketi içerisinde döndürelim.
Vue JS
var uygulama = new Vue({
el: '#icerik',
data: {
veriler: [
{ isim: 'Ali' },
{ isim: 'Veli' },
{ isim: 'Metin' }
]
}
})
HTML
<div id="icerik">
<ol>
<li v-for="veri in veriler"> {{ veri.isim}} </li>
</ol>
</div>
yukarıdaki örnekte de verileri içerisindeki veriyi <li> olarak listeleme etiketi içerisinde yazdırdık. Örneği aşağıdan inceleyebilirsiniz.
HTML
<div id="icerik" class="p-4">
<p v-for="(veri, key) in veriler">
<b>{{key}}.</b> {{ veri.isim}} </p>
</div>
Yukarıdaki örneğin çıktısı:
Son olarak söylemek istediğim aynı etiket içerisinde v-if ve v-for direktiflerini beraber kullanmayın.
Tasarımcılara bu konuda cazip gelen iki durum var:
- <li v-for="kullanıcı in kullanıcılar" v-if="kullanıcı.aktifMi"> bunu bu şekilde değil de kullanıcılar verisini döndürmeden önce aktifKullanicilar diye bir değer oluşturup listelenecekler buraya filtre ile atılabilir sonra listelenebilir.(filterelere değineceğiz anlaşılması açısından değindim)
- ikincisi bir li elemanında if ve for kullanacaksanız öncesinde bir etiket açın if direktifini girin daha sonrasında li içerisinde for kullanarak verilerinizi listeleyin. Örn:
<ul v-if="goster">
<li v-for="kullanici in kullanicilar">{{kullanici.isim}}</li>
</ul>
Bu dersimiz de burada bitti. Bundan sonra Components yani Bileşenleri işleyeceğiz. Görüşmek üzere...