ASP.NET Core Blazor temelleri
Uyarı
ASP.NET Core'un bu sürümü artık desteklenmiyor. Daha fazla bilgi için bkz . .NET ve .NET Core Destek İlkesi. Geçerli sürüm için bu makalenin .NET 9 sürümüne bakın.
Temeller makaleleri, temel Blazor kavramları hakkında rehberlik sağlar. Bazı kavramlar, bu makalenin sonraki bölümünde daha ayrıntılı olarak açıklanan ve Razor makalelerinde ayrıntılı olarak ele alınan temel bileşenlerine yönelik bir anlayışla bağlantılıdır.
Statik ve etkileşimli işleme kavramları
Razor bileşenleri statik olarak işlenir veya etkileşimli olarak işlenir.
Statik veya statik işleme , bileşenin kullanıcı ile .NET/C# kodu arasında etkileşim için kapasite olmadan işlendiği anlamına gelen sunucu tarafı bir senaryodur. JavaScript ve HTML DOM olayları etkilenmez, ancak istemcideki hiçbir kullanıcı olayı sunucuda çalışan .NET ile işlenemez.
Etkileşimli /etkileşim veya etkileşimli işleme , bileşenin C# kodu aracılığıyla .NET olaylarını ve bağlamayı işleme kapasitesine sahip olduğu anlamına gelir. .NET olayları ve bağlama, ASP.NET Core çalışma zamanı tarafından sunucuda veya WebAssembly tabanlı Blazor çalışma zamanı tarafından istemcideki tarayıcıda işlenir.
Önemli
Bir Blazor Web App kullanırken, belgelerdeki örnek bileşenlerin Blazor çoğu, makalelerde ele alınan kavramların çalışması ve gösterilmesi için etkileşim gerektirir. Bir makale tarafından sağlanan örnek bir bileşeni Blazor Web Appiçinde test ettiğinizde, uygulamanın genel etkileşimli çalışma özelliğini benimsediğinden veya bileşenin etkileşimli işleme modunu kullandığından emin olun. Bu konu hakkında daha fazla bilgi, Blazor belge kümesinin ilerleyen bölümlerinde yer alan Bileşenleri bölümünde ASP.NET Core Blazor işleme modları tarafından sağlanır.
Bu kavramlar ve statik ve etkileşimli işlemeyi denetleme hakkında daha fazla bilgi için belgelerin devamında yer alan ASP.NET Core Blazor işleme modları makalesinde Blazor bulabilirsiniz.
İstemci ve sunucu işleme kavramları
Belgeler boyuncaBlazor, kullanıcının sisteminde gerçekleşen etkinliğin istemci veya istemci tarafında gerçekleştiği söylenir. Bir sunucuda gerçekleşen etkinliğin sunucuda veya sunucu tarafında gerçekleştiği söylenir.
İşleme terimi, tarayıcıların görüntülediği HTML işaretlemesini üretmek anlamına gelir.
İstemci tarafı işleme (CSR), son HTML işaretlemesinin istemcideki .NET WebAssembly çalışma zamanı tarafından oluşturulduğu anlamına gelir. Uygulamanın istemci tarafından oluşturulan kullanıcı arabirimi için bu tür bir işleme için sunucudan istemciye HTML gönderilmez. Kullanıcının sayfayla etkileşimi varsayılır. İstemci tarafında statik işleme diye bir kavram yoktur. CSR'nin etkileşimli olduğu varsayılır, bu nedenle sektör veya belgelerde "etkileşimli istemci tarafı işleme" ve "etkileşimli CSR" kullanılmaz.Blazor
Sunucu tarafı işleme (SSR), son HTML işaretlemesinin sunucudaki ASP.NET Core çalışma zamanı tarafından oluşturulduğu anlamına gelir. HTML, istemcinin tarayıcısı tarafından görüntülenmesi için bir ağ üzerinden istemciye gönderilir. Uygulamanın sunucu tarafından oluşturulan kullanıcı arabirimi için bu işleme türünde istemci tarafından HTML oluşturulmaz. SSR iki çeşit olabilir:
- Statik SSR: Sunucu, kullanıcı etkileşimi veya bileşen durumunu koruma sağlamayan Razor statik HTML üretir.
- Etkileşimli SSR: Blazor olaylar kullanıcı etkileşimi sağlar ve Razor bileşen durumu çerçeve tarafından Blazor korunur.
Ön kayıt , işlenen denetimler için olay işleyicilerini etkinleştirmeden başlangıçta sunucudaki sayfa içeriğini işleme işlemidir. Sunucu, uygulamanın kullanıcılara daha duyarlı hissetmesini sağlayan ilk isteğe yanıt olarak sayfanın HTML kullanıcı arabirimini mümkün olan en kısa sürede verir. Ön kayıt, arama motorlarının sayfa derecesini hesaplamak için kullandığı ilk HTTP yanıtının içeriğini işleyerek Arama Altyapısı İyileştirmesini (SEO) da geliştirebilir. Prerendering işlemi, her zaman sunucuda veya istemcide gerçekleşen son işleme ile tamamlanır.
Razor bileşenleri
Blazor uygulamaları genellikle yalnızca Razor olarak adlandırılan bileşenlerini temel alır. Bir bileşen, sayfa, iletişim kutusu veya veri girişi formu gibi bir kullanıcı arabirimi öğesidir. Bileşenler, .NET derlemelerinde yerleşik olarak bulunan .NET C# sınıflarıdır:
Razor, bileşenlerin genellikle istemci tarafı UI mantığı ve kompozisyonu için bir Razor işaretleme sayfası biçiminde nasıl yazıldığını ifade eder.
Razor, HTML işaretlemesini geliştirici üretkenliği için tasarlanmış C# koduyla birleştirmeye yönelik bir söz dizimidir.
Razor dosyaları .razor
dosya uzantısını kullanır.
Bazı Blazor geliştiricileri ve çevrimiçi kaynaklar "Blazor bileşenleri" terimini kullansa da, belgelerde bu terim engellenir ve evrensel olarak "Razor bileşenleri" veya "bileşenler" kullanılır.
Blazor belgesi, bileşenleri göstermek ve tartışmak için çeşitli konvansiyonları benimser:
- Örnekler genellikle ASP.NET Core/C# kodlama kurallarına ve mühendislik yönergelerine bağlıdır. Daha fazla bilgi için aşağıdaki kaynaklara bakın:
- Proje kodu, dosya yolları ve adları, proje şablonu adları ve diğer özel terimler Amerikan İngilizcesi olarak yazılmıştır ve genellikle kod blokları içine alınmıştır.
- Bileşenlere genellikle C# sınıf adları (Pascal büyük/küçük harf) ve ardından "bileşen" sözcüğü denir. Örneğin, tipik bir dosya karşıya yükleme bileşeni "
FileUpload
bileşeni" olarak adlandırılır. - Genellikle, bir bileşenin C# sınıf adı dosya adıyla aynıdır.
- Yönlendirilebilir bileşenler, genellikle kebab-case formatında olan göreli URL'lerini bileşenin sınıf adıyla ayarlarlar. Örneğin, bir
FileUpload
bileşeni, göreli/file-upload
URL'de işlenen bileşene ulaşmak için yönlendirme yapılandırmasını içerir. Yönlendirme ve gezinti, ASP.NET Core Blazor yönlendirme ve gezinti kapsamındadır. - Bir bileşenin birden çok sürümü kullanıldığında, bunlar sıralı olarak numaralandırılır. Örneğin,
FileUpload3
bileşenine/file-upload-3
ulaşılır. -
Razor
bir bileşen tanımının (
.razor file
) en üstündeki yönergeler şu sırayla yerleştirilir:@page
,@rendermode
(.NET 8 veya üzeri),@using
deyimler, alfabetik sırada diğer yönergeler. - Üyeler için
private
gerekli olmasa da, makale örneklerinde ve örnek uygulamalarda erişim değiştiricileri kullanılır. Örneğinprivate
,maxAllowedFiles
adlı bir alanıprivate int maxAllowedFiles = 3;
olarak bildirmek için belirtilir. -
Bileşen parametre değerleri Razor ayrılmış
@
sembolüyle başlar, ancak bu gerekli değildir. Değişmez değerler (örneğin, boole değerleri), anahtar sözcükler (örneğin,this
) venull
bileşen parametre değerleri@
ile ön eklenmez, ancak bu yalnızca bir dokümantasyon geleneğidir. İsterseniz, kendi kodunuzda sabitlere@
ön eki ekleyebilirsiniz. - C# sınıfları
this
anahtar sözcüğünü kullanır ve oluşturucularda atanan alanlara alt çizgi (_
) ön eki eklemekten kaçınır; bu durum, ASP.NET Core framework mühendislik yönergeleri ile farklılık gösterir. - Birincil oluşturucuları (C# 12 veya üzeri) kullanan örneklerde, birincil oluşturucu parametreleri genellikle doğrudan sınıf üyeleri tarafından kullanılır. Makale örneklerinde, yatay kaydırmayı azaltmak için kod satırları bölünür. Bu boşluklar yürütmeyi etkilemez, ancak projenize yapıştırırken kaldırılabilir.
Aşağıda örnek bir sayaç bileşeni ve Blazor proje şablonundan oluşturulan bir uygulamanın bir bölümü verilmiştir. Ayrıntılı bileşen kapsamı, belgelerin devamında yer alan Bileşenler makalelerinde bulunur. Aşağıdaki örnekte, belgelerin devamında Yer alan Bileşenler makalelerine ulaşmadan önce Temeller makalelerinde görülen Bileşenler kavramları gösterilmektedir.
Counter.razor
:
Bileşen, etkileşimli işleme modunun bir üst bileşenden devralındığını veya uygulamaya genel olarak uygulandığını varsayar.
@page "/counter"
<PageTitle>Counter</PageTitle>
<h1>Counter</h1>
<p role="status">Current count: @currentCount</p>
<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
@code {
private int currentCount = 0;
private void IncrementCount() => currentCount++;
}
Bileşen, etkileşimli işleme modunun bir üst bileşenden devralındığını veya uygulamaya genel olarak uygulandığını varsayar.
@page "/counter"
<PageTitle>Counter</PageTitle>
<h1>Counter</h1>
<p role="status">Current count: @currentCount</p>
<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
@code {
private int currentCount = 0;
private void IncrementCount() => currentCount++;
}
@page "/counter"
<PageTitle>Counter</PageTitle>
<h1>Counter</h1>
<p role="status">Current count: @currentCount</p>
<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
@code {
private int currentCount = 0;
private void IncrementCount()
{
currentCount++;
}
}
@page "/counter"
<PageTitle>Counter</PageTitle>
<h1>Counter</h1>
<p role="status">Current count: @currentCount</p>
<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
@code {
private int currentCount = 0;
private void IncrementCount()
{
currentCount++;
}
}
@page "/counter"
<h1>Counter</h1>
<p>Current count: @currentCount</p>
<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
@code {
private int currentCount = 0;
private void IncrementCount()
{
currentCount++;
}
}
@page "/counter"
<h1>Counter</h1>
<p>Current count: @currentCount</p>
<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
@code {
private int currentCount = 0;
private void IncrementCount()
{
currentCount++;
}
}
Önceki Counter
bileşeni:
- İlk satırda
@page
yönergesi ile yolunu ayarlar. - Sayfa başlığını ve üstbilgiyi ayarlar.
- Geçerli sayıyı
@currentCount
ile gösterir.currentCount
,@code
bloğunun C# kodunda tanımlanan bir tamsayı değişkenidir. -
IncrementCount
bloğunda da bulunan ve@code
değişkeninin değerini artırancurrentCount
yöntemini tetiklemek için bir düğme görüntüler.
İşleme modları
Temel Bilgiler düğümündeki makaleler işleme modları kavramına başvuruda bulunur. Bu konu, Temel Bilgiler makale düğümünden sonra gelen Bileşenler düğümündeki ASP.NET Core işleme modları makalesinde ayrıntılı olarak ele alınmıştır.
Makale düğümündeki render alma modu kavramlarına yönelik erken referanslar için şu anda yalnızca aşağıdakilere dikkat edin:
içindeki Blazor Web App her bileşen, kullandığı barındırma modelini, nerede işlendiğini ve sunucuda statik olarak işlenip işlenmediğini, sunucuda kullanıcı etkileşimi için işlenip işlenmeyeceğini veya istemcide kullanıcı etkileşimi için işlenip işlenmediğini belirlemek için bir işleme modu benimser (genellikle sunucuda ön oturum açma ile).
Blazor Serverve Blazor WebAssembly .NET 8 öncesi ASP.NET Core sürümlerine yönelik uygulamalar, işleme modlarına değil barındırma modeli kavramlarına bağlı kalır. İşleme modları kavramsal olarak .NET 8 veya sonraki sürümlerde Blazor Web App'lere uygulanır.
Aşağıdaki tabloda, Blazor Web App içindeki Razor bileşenlerini işlemek için kullanılabilir işleme modları gösterilmektedir. Bileşen örneği veya bileşen tanımındaki @rendermode
yönergesiyle bileşenlere görüntüleme modları uygulanır. Uygulamanın tamamı için bir işleme modu ayarlamak da mümkündür.
Veri Akışı Adı | Açıklama | Görüntü oluşturma konumu | Etkileşimli |
---|---|---|---|
Statik Sunucu | Statik sunucu tarafı işleme (statik SSR) | Sunucu | Hayır |
Etkileşimli Sunucu | Etkileşimli sunucu tarafı işleme (etkileşimli SSR) Blazor Server kullanarak | Sunucu | Evet |
Etkileşimli WebAssembly | İstemci tarafı işleme (CSR) † kullanarak Blazor WebAssembly | Müşteri | Evet |
Etkileşimli Otomatik | Başlangıçta Blazor Server kullanılarak etkileşimli SSR, paket Blazor indirildikten sonraki ziyaretlerde CSR kullanılır. | Sunucu, ardından istemci | Evet |
†İstemci tarafı işlemenin (CSR) etkileşimli olduğu varsayılır. "Etkileşimli istemci taraflı render" ve "etkileşimli CSR" sektör tarafından veya Blazor belgelerde kullanılmaz.
İşleme modlarıyla ilgili önceki bilgiler, Temel Bilgiler düğümü makalelerini anlamak için bilmeniz gereken tek şeydir. Eğer Blazor konusunda yeniyseniz ve içindekiler tablosunda makaleleri sırayla okuyorsanız, Bileşenler düğümündeki ASP.NET Core Blazor işleme modları makalesine ulaşana kadar işleme modları hakkında ayrıntılı bilgi edinmeyi erteleyebilirsiniz.
Belge Nesne Modeli (DOM)
Belge Nesne Modeli başvuruları DOM kısaltmasını kullanır.
Daha fazla bilgi edinmek için aşağıdaki kaynaklara bakın:
Uygulamalar için Blazor WebAssembly .NET API'lerinin alt kümesi
Tarayıcıda Blazor WebAssembly tarafından desteklenen belirli .NET API'lerinin seçilmiş bir listesi mevcut değil. Ancak, WebAssembly'de desteklenmeyen .NET API'lerini bulmak için el ile [UnsupportedOSPlatform("browser")]
ek açıklamalı .NET API'lerinin listesini arayabilirsiniz.
Not
.NET başvuru kaynağına yönelik belge bağlantıları genellikle deponun varsayılan dalını yükler ve bu dal .NET'in sonraki sürümü için geçerli geliştirmeyi temsil eder. Belirli bir sürüm için etiket seçmek amacıyla Dalları veya etiketleri değiştir açılır listesini kullanın. Daha fazla bilgi için bkz. ASP.NET Core kaynak kodunun sürüm etiketini seçme (dotnet/AspNetCore.Docs #26205).
Daha fazla bilgi edinmek için aşağıdaki kaynaklara bakın:
- Sınıf kitaplıkları: İstemci tarafı tarayıcı uyumluluk çözümleyicisi
-
API'lere belirli platformlarda desteklenmeyen açıklama ekleme (
dotnet/designs
GitHub deposu
Örnek uygulamalar
Belge örnek uygulamaları, inceleme ve indirme için kullanılabilir:
Blazor GitHub örnek deposu (dotnet/blazor-samples
)
İlk olarak üzerinde çalıştığınız .NET sürümüyle eşleşen sürüm klasörünü seçerek örnek bir uygulama bulun.
Depodaki uygulamaları örnekler:
- Blazor Web App
- Blazor WebAssembly
- Blazor Web App Filmler öğretici örneği (Blazor film veritabanı uygulaması oluşturma (Genel Bakış))
- Blazor Web App ile SignalR (ASP.NET Core SignalR ile Blazor kullanın)
- İki Blazor Web App ve bir Blazor WebAssembly uygulaması, web (sunucu) API'lerini çağırmak için (ASP.NET Core Blazor uygulamasından web API'sini çağırma)
- Blazor Web App OIDC (BFF ve BFF olmayan desenler) ile (OpenID Connect (OIDC) ile ASP.NET Çekirdeğin Blazor Web App güvenliğini sağlama)
- Blazor Web App Entra ile ASP.NET Core'u Microsoft Entra ID ile Güvenceye Alma Blazor Web App
- Blazor WebAssembly kapsam etkinleştirilmiş günlüğe kaydetme (ASP.NET Core Blazor günlüğü)
- Blazor WebAssemblyASP.NET Core ile (IdentityBlazor WebAssemblyIdentity)
- .NET MAUI Blazor Hybrid sınıf kitaplığı (RCL) tarafından sağlanan paylaşımlı bir kullanıcı arabirimine sahip Blazor Web App bir uygulama oluşturun (Razor bir .NET MAUIBlazor Hybrid uygulama oluşturun Blazor Web App)
- Ek örnekler (bkz. Blazor örnekleri GitHub deposu README dosyası)
Depodaki uygulamaları örnekler:
- Blazor Web App
- Blazor WebAssembly
- Blazor Web App Filmler öğretici örneği (Blazor film veritabanı uygulaması oluşturma (Genel Bakış))
- Blazor Web App ile SignalR (ASP.NET Core SignalR ile Blazor kullanın)
- İki Blazor Web App ve web (sunucu) API'lerini çağırmak için bir Blazor WebAssembly uygulaması (ASP.NET Core Blazor uygulamasından bir web API'si çağırma)
- Blazor Web App OIDC (BFF ve BFF olmayan desenler) ile (OpenID Connect (OIDC) ile ASP.NET Çekirdeğin Blazor Web App güvenliğini sağlama)
- Blazor WebAssembly kapsamlar etkinleştirildiğinde günlüğe kaydetme (ASP.NET Core Blazor günlüğü)
- Blazor WebAssembly ile ASP.NET Core (ASP.NET Core ile Güvenli Blazor WebAssemblyIdentity)
- .NET MAUI Blazor Hybrid ile bir uygulama ve Blazor Web App paylaşılan bir kullanıcı arabirimi bir sınıf kitaplığı (RCL) (Razor.NET MAUI ile bir uygulama oluşturun Blazor HybridBlazor Web App)
- Ek örnekler (bkz. Blazor örnekleri GitHub deposu README dosyası)
Örnek depo iki tür örnek içerir:
- Kod parçacığı örnek uygulamaları, makalelerde görünen kod örneklerini sağlar. Bu uygulamalar derlenebilir ancak çalıştırılabilir uygulamalar olmayabilir. Bu uygulamalar yalnızca makalelerde görünen örnek kodu elde etmek için kullanışlıdır.
- Aşağıdaki senaryolar için Blazor makalelerine eşlik eden örnek uygulamalar derlenir ve çalıştırılır.
- Blazor Server ve Blazor WebAssembly ile SignalR
- Blazor WebAssembly kapsamlar etkinleştirilmiş günlüğe kaydetme
Daha fazla bilgi için, depodaki örneklerin listesi ve indirme yönergeleri için bkz. Blazor örnekleri GitHub deposu README dosyası.
ASP.NET Core deposunun Temel Test Uygulaması da çeşitli Blazor senaryolar için yararlı bir örnek kümesidir:
BasicTestApp
ASP.NET Çekirdek başvuru kaynağında (dotnet/aspnetcore
)
Not
.NET başvuru kaynağına yönelik belge bağlantıları genellikle deponun varsayılan dalını yükler ve bu dal .NET'in sonraki sürümü için geçerli geliştirmeyi temsil eder. Belirli bir sürüm için bir etiket seçmek üzere Dalları veya etiketleri değiştir açılır listesini kullanın. Daha fazla bilgi için bkz. ASP.NET Core kaynak kodunun sürüm etiketini seçme (dotnet/AspNetCore.Docs #26205).
Bayt çarpanları
.NET bayt boyutları, 1024'ün kuvvetlerine dayanan ondalık olmayan bayt katlarını ifade etmek için metrik ön ekleri kullanır.
Ad (kısaltma) | Boyut | Örnek |
---|---|---|
Kilobayt (KB) | 1.024 bayt | 1 KB = 1.024 bayt |
Megabayt (MB) | 1.0242 bayt | 1 MB = 1.048.576 bayt |
Gigabayt (GB) | 1.0243 bayt | 1 GB = 1.073.741.824 bayt |
Destek istekleri
Yalnızca belgelerle ilgili sorunlar dotnet/AspNetCore.Docs
deposu için uygundur.
Ürün desteği için bir belge sorunu açmayın. Aşağıdaki destek kanallarından biri veya daha fazlası aracılığıyla yardım isteyin:
Çerçevede veya ürün geri bildiriminde olası bir hata için, dotnet/aspnetcore
sorunlarında ASP.NET Core ürün birimi için bir sorun açın Hata raporları genellikle aşağıdakileri gerektirir:
- Sorunun net açıklaması: Sorunu açarken ürün birimi tarafından sağlanan GitHub sorun şablonundaki yönergeleri izleyin.
- Minimal yeniden oluşturma projesi: Ürün birimi mühendislerinin indirip çalıştırması için GitHub'a bir proje yerleştirin. Projeyi, sorunun açılış açıklamasına çapraz bağlayın.
Bir Blazor makalesiyle ilgili olası bir sorun için bir belge sorunu açın. Belge sorununu açmak için makalenin en altındaki Belge sorunu geri bildirimi aç bağlantısını kullanın. Sorununuza eklenen meta veriler izleme verileri sağlar ve makalenin yazarına otomatik olarak ping atar. Konu, belge sorununu açmadan önce ürün birimiyle tartışıldıysa, belge sorununun açılış açıklamasına mühendislik sorununa bir çapraz bağlantı yerleştirin.
Visual Studio ile ilgili sorunlar veya geri bildirim için Visual Studio'nun içinden Sorun Bildir veya Özellik Öner hareketlerini kullanın. Bu hareketler Visual Studio'nun iç sorunlarını açar. Daha fazla bilgi için bkz . Visual Studio Geri Bildirimi.
Visual Studio Code ile ilgili sorunlar için topluluk destek forumlarında destek isteyin. Hata raporları ve ürün geri bildirimi için microsoft/vscode
GitHub deposunda bir sorun açın.
Blazor belgeleri için GitHub sorunları, Blazor.Docs
projesinde önceliklendirme için otomatik olarak işaretlenir (dotnet/AspNetCore.Docs
GitHub deposu). Lütfen, özellikle hafta sonları ve tatillerde yanıt için lütfen kısa bir süre bekleyin. Belge yazarları hafta içi genellikle 24 saat içinde yanıt verir.
Blazor kaynaklarına topluluk bağlantıları
Topluluk tarafından sağlanan Blazor kaynaklarına yönelik bağlantıların bir koleksiyonu için, Awesome Blazor adresini ziyaret edin.
Not
Microsoft, Awesome Blazor adresinde ile burada açıklanan ve bağlanan topluluk ürün ve hizmetlerinin çoğuna sahip değildir, bakımını yapmaz veya desteklemez.
ASP.NET Core