c# Web

Mevsimlere Ait Ayları Select Etiketiyle Listeleyen Core Mvc Uygulaması

Günlük hayatta en çok bildiğimiz konulardan biri de mevsimler ve bu mevsimlere ait olan aylardır. Bı uygulamada birbirinden bağımsız olan bu bilgileri ayrı ayrı dizide tanımlayıp mevsimlere ait ayları select etiketiyle web sayfasında göstereceğiz.

Visual Studio 2022 programını açalım.

Ekrana gelen Create a new project diyalog pencersinde dil olarak c#, platform olarak All platforms, ortam olarak Web seçelim. Ekrana gelen şablonlardan Asp.Net Core Empty seçelim. Next diyerek devam edelim.

Proje ismi olarak MevsimlerListesi yazalım. Next diyerek devam edelim. Ekrana gelen pencerede Framework olarak .Net 8,0 seçelim. Configure for Https onay kutusunu iptal edelim. Create diyerek projeyi oluşturalım.

Böylece boş bir Core projesi oluşturmuş olduk. Sıra geldi projede MVC platformlarını kurma işlemini yapmaya. Öncelikle program.cs isimli dosyada projenin Mvc projesi olduğunu belirtelim.

var builder = WebApplication.CreateBuilder(args);
builder.Services.AddControllerWithViews();
var app = builder.Build();

app.Run();

Daha sonra projeye M harfini temsil eden Models, V harfini temsil eden Views, C harfini temsil eden Controllers  klasörlerini ekleyelim. Controllers klasörü içine MevsimComtroller isminde bir controller dosyası ekleyelim. Dosyamızın içeriği aşağıdaki gibi olacaktır.

using Microsoft.AspNetCore.Mvc;

namespace MevsimlerListesi.Controllers
{
    public class MevsimController : Controller
    {
        public IActionResult Index()
        {
            return View();
        }
    }
}

Burada dosya ismi verilirken şunlara dikkat etmeliyiz. Proje ilk çalıştırıldığında hangi bölüme gidecekse o bölüm Controller kısmında belirtilir. Bu dosyada proje ilk Mevsim kısmına gidecektir. Controller yazısı ise o dosyanın hangi amaç için kullanıldığını belirtir. Controller dosyası bir view çalıştırır. Burada view dosyamız Index dosyasıdır. Bu dosyayı Aylar olarak değiştirelim. Şimdi bu dosyayı Views/Mevsim klasörü altında oluşturalım. Bu klasör içinde bir Razor View dosyası oluşturulur. Dosyayı şöyle düzenleyelim.

@{
    ViewData["Title"] = "Mevsim ve Ay Seçimi";
}

Projemizi çalıştıralım. Web sayfası çalışmayacak ya da wwwroot klasörü içinde yer alan dosyayı gösterecektir. Çünkü projenin başlangıç dosyasını belirtmedik. Bunu program.cs tarafında şöyle yapmalıyız.

var builder = WebApplication.CreateBuilder(args);
builder.Services.AddControllerWithViews();
var app = builder.Build();

app.MapControllerRoute(
    name: "default",
    pattern: "{controller=Mevsim}/{action=Aylar}"
    );

app.Run();

Projeyi çalıştıralım. Hatasız bir şekilde sonucu görürsünüz. Controller tarafında gerekli işlemleri yapalım.

using Microsoft.AspNetCore.Mvc;

 
namespace WebApplication2.Controllers
{
    public class MevsimController : Controller
    {
        public IActionResult Aylar()
        {
            // Mevsimler dizisi
            string[] seasons = { "İlkbahar", "Yaz", "Sonbahar", "Kış" };
 
            // Her mevsime ait aylar dizisi
            string[] months = { "Ocak", "Şubat", "Mart", "Nisan", "Mayıs", "Haziran", "Temmuz", "Ağustos", "Eylül", "Ekim", "Kasım", "Aralık"};
 
            // ViewBag ile mevsimlere ait ayları taşımak
            ViewBag.Seasons = seasons;
            ViewBag.Months = months;
 
            return View();
        }
    }
}

Şimdide views tarafında gerekli işlemleri yapalım.

@{
    ViewData["Title"] = "Mevsim ve Ay Seçimi";
}
 
@{
    var months = ((string[])ViewBag.Months);
    var x = 0;
}
 
<h3>Mevsim ve Aylar</h3>
 
<select id="season" name="selectedSeason" size="16">
    @foreach (var season in ViewBag.Seasons)
    {
        <optgroup label=@season>
            @for (int i = 2; i < months.Length+3; i++)
            {
                <option>@months[i]</option>
 
                x++;
                @if (x>2)
                {
                    x = 0;
                    break;
                }
            }
        </optgroup>
    }
</select>

Projeyi çalıştırıp sonucu görelim.


Etiketler
core mvc views mevsimler aylar 
İlgili Makaleler
Web Tabanlı Uygulama Geliştirme Dersi İkinci Dönem İkinci Yazılı Çalışma Soruları
2020 TYT Matematik Ortakatlı Kuralıyla İlgili Sorunun Çözümünü c# Diliyle Web Form Sayfasında Kodlama
Core Mvc Projesinde SqlServer Kullanarak Üye Takibi Yapan Web Projesini Tasarlama1
Web Tabanlı Uygulama Geliştirme Dersi İkinci Dönem Birinci Yazılı Çalışma Soruları
Visual Studio 2022 Programında Asp.Net Web Application Şablonu Görünmüyor Hatasını Düzeltme
Core Mvc Projesinde Tuple Nesneleri Post Etme ve Yakalama İşlemleri
Seri Port Yardımıyla Arduino Devresine Bağlanıp Ledleri Asp.Net Web Uygulamasından Yakıp Söndürme
Sitenin Alexa Dünya Sıralamasını Kodlarla Öğrenme
Personele Ait Boy ve Kilo Bilgilerine Göre İdeal Kiloyu Bulan Uygulamayı Asp.Net İle Yapınız
Core Mvc Projesinde SqlServer Kullanarak Üye Takibi Yapan Web Projesini Tasarlama4
Bir Otobüs Firmasına Ait Bilet Satış İşlemlerini Class(Sınıf) Tanımlayarak Yapan c# Form Uygulaması
Asp.Net Uygulamasında Manual Olarak JSON Oluşturma
Asp.Net Uygulamalarında Modal PopUp Oluşturma
Web Uygulamalarında SqLite Kullanımı
Asp.Net Uygulamalarında DataList (Veri Listeleme) Kontrolü
Core Mvc Projesinde SqlServer Kullanarak Üye Takibi Yapan Web Projesini Tasarlama2
C# Uygulamasında Miladi Takvimi Hicri Takvime, Hicri Takvimi Miladi Takvime Dönüştürme
2022 TYT Matematik Onbirinci Sorunun Çözümünü c# Diliyle Web Form Sayfasında Kodlama
Core Mvc Projesinde SqlServer Kullanarak Üye Takibi Yapan Web Projesini Tasarlama3
RadioButton ile Cinsiyet Bilgisini Alan Asp.Net c# Uygulaması

Yorum Ekle
   
Kötü İyi