cari
  • Log masuk
  • Daftar
Penetapan semula kata laluan berjaya

Ikuti proiects vou berminat dengan andi aet terbaru mengenai mereka

Jadual Kandungan
Use dotnet new blazorwasm to scaffold the app
Understand the difference between blazorwasm and blazorwasm-hosted
Reference NuGet packages correctly in .csproj
Deploying requires static hosting — no .NET runtime on server
Rumah pembangunan bahagian belakang Tutorial C#.Net Bagaimana untuk membuat aplikasi Blazor WebAssembly dengan C#?

Bagaimana untuk membuat aplikasi Blazor WebAssembly dengan C#?

Jan 22, 2026 am 01:22 AM

Running dotnet new blazorwasm scaffolds a client-side Blazor WebAssembly app with default routing and runtime; use --hosted for an API backend, ensure correct NuGet references and target framework, and deploy via static hosting.

How to create a Blazor WebAssembly app with C#?

Use dotnet new blazorwasm to scaffold the app

You get a working Blazor WebAssembly app immediately with this single command. It sets up the project structure, client-side runtime, and default routing — no manual config needed for basic use.

Run it like this:

dotnet new blazorwasm -n MyBlazorApp
cd MyBlazorApp
dotnet run

The generated app runs on https://localhost:5001 (HTTPS) and http://localhost:5000 (HTTP). If you see certificate errors in browser, trust the dev cert with dotnet dev-certs https --trust.

Understand the difference between blazorwasm and blazorwasm-hosted

The default blazorwasm template produces a purely client-side app: all C# code compiles to WebAssembly and runs in the browser. No server dependency beyond static file hosting.

If you need a backend API (e.g., for database access or auth), use the hosted variant:

dotnet new blazorwasm --hosted -n MyHostedApp
  • Creates three projects: Client, Server, and Shared
  • Server is an ASP.NET Core API project that serves the client and hosts controllers
  • Client still runs as WebAssembly but calls Server via HTTP (e.g., HttpClient.GetAsync("weatherforecast"))
  • Don’t confuse this with Blazor Server — there’s no SignalR connection or server-side rendering here

Reference NuGet packages correctly in .csproj

Your Client project must reference Microsoft.AspNetCore.Components.Web and Microsoft.AspNetCore.Components.WebAssembly. The SDK-style project file does this automatically — but if you add custom targets or migrate manually, missing or outdated versions break compilation.

Check these lines exist in your MyBlazorApp.Client.csproj:

<PackageReference Include="Microsoft.AspNetCore.Components.Web" Version="8.0.0" />
<PackageReference Include="Microsoft.AspNetCore.Components.WebAssembly" Version="8.0.0" />

Also ensure <TargetFramework>net8.0</TargetFramework> matches your SDK version. Mismatched TFMs cause cryptic errors like The type or namespace name 'WebAssembly' does not exist.

Deploying requires static hosting — no .NET runtime on server

After dotnet publish -c Release, output goes to bin/Release/net8.0/publish/wwwroot. That folder contains HTML, JS, DLLs, and dotnet.wasm — everything needed to run.

You can serve it with any static host (NGINX, GitHub Pages, Azure Static Web Apps), but remember:

  • No server-side C# execution — all logic lives in the browser
  • Initial load time depends on total DLL size; trim unused assemblies with <PublishTrimmed>true</PublishTrimmed>
  • Browser security restrictions apply: no direct file system access, limited threading, no System.Drawing support
  • CORS matters only when calling external APIs — same-origin requests to your own /api/* endpoints work fine if the backend is co-hosted or properly configured

The biggest gotcha isn’t setup — it’s assuming WebAssembly behaves like .NET on Windows. It doesn’t. Things like reflection, dynamic code generation, or synchronous I/O are either restricted or behave differently.

Atas ialah kandungan terperinci Bagaimana untuk membuat aplikasi Blazor WebAssembly dengan C#?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

Stock Market GPT

Stock Market GPT

Penyelidikan pelaburan dikuasakan AI untuk keputusan yang lebih bijak

Alat popular

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk mengesahkan alamat e-mel dalam C#? (Corak regex) Bagaimana untuk mengesahkan alamat e-mel dalam C#? (Corak regex) Mar 08, 2026 am 12:06 AM

Adalah disyorkan untuk menggunakan biasa rasmi ringan Microsoft ^[a-zA-Z0-9._% -] @[a-zA-Z0-9.-] \.[a-zA-Z]{2,}$ untuk pengesahan format e-mel asas, meliputi 99% daripada input sebenar; cara yang lebih dipercayai ialah menggunakan pembina MailAddress dan hanya menangkap FormatException, sambil mengesahkan rentetan null/kosong terlebih dahulu.

Bagaimana untuk menggunakan refleksi untuk mendapatkan nilai harta dalam C#? (GetType) Bagaimana untuk menggunakan refleksi untuk mendapatkan nilai harta dalam C#? (GetType) Mar 06, 2026 am 12:15 AM

GetProperty harus digunakan bersama dengan GetValue untuk mendapatkan nilai harta dan bukannya hanya memanggil GetType; adalah perlu untuk memberi perhatian kepada butiran seperti keterlihatan harta, perhubungan warisan dan pengindeks, dan disyorkan untuk cache PropertyInfo untuk meningkatkan prestasi.

Bagaimana untuk menggunakan sifat dengan get set dalam C#? (Encapsulation) Bagaimana untuk menggunakan sifat dengan get set dalam C#? (Encapsulation) Mar 10, 2026 am 12:33 AM

get/set tidak hanya menambah kurungan, tetapi merangkum titik permulaan: medan eksplisit diperlukan, operasi yang memakan masa dielakkan, ArgumentException dilemparkan apabila pengesahan gagal, pengubah suai akses berbeza disokong, init terhad kepada senario permulaan dan atribut logik pada asasnya ialah kaedah. Perhatian khusus mesti diberikan kepada penyahpepijatan dan prestasi.

Bagaimana untuk memisahkan rentetan dengan pembatas dalam C#? (String.Split) Bagaimana untuk memisahkan rentetan dengan pembatas dalam C#? (String.Split) Mar 12, 2026 am 12:21 AM

Ya, String.Split mengembalikan rentetan kosong secara lalai, menyebabkan item kosong disebabkan oleh pembatas berterusan atau pertama dan terakhir; anda perlu menggunakan StringSplitOptions.RemoveEmptyEntries untuk menapis, atau menapis secara manual; char[] digunakan untuk pemisahan aksara tunggal, dan rentetan[] digunakan untuk pemisahan subrentetan; Span.Split boleh mengelakkan peruntukan; melepasi had atas nombor akan memotong keputusan.

Bagaimana untuk menulis ke fail teks dalam C#? (Contoh StreamWriter) Bagaimana untuk menulis ke fail teks dalam C#? (Contoh StreamWriter) Mar 05, 2026 am 12:14 AM

Anda mesti menggunakan menggunakan untuk memastikan bahawa StreamWriter dikeluarkan dengan betul. Laluan perlu dibina dengan Path.Combine dan direktori mesti dibuat terlebih dahulu. File.WriteAllText atau File.AppendAllText lebih disukai untuk memudahkan operasi.

Bagaimana untuk menggunakan jenis nullable dalam C#? (Jenis rujukan boleh batal) Bagaimana untuk menggunakan jenis nullable dalam C#? (Jenis rujukan boleh batal) Mar 06, 2026 am 12:14 AM

Selepas mendayakan nullable, rentetan bermaksud bukan nol (ralat akan dilaporkan jika null diberikan atau dereference tidak dikesan), string? secara eksplisit membenarkan null; fail lama perlu #nullableenable secara eksplisit untuk berkuat kuasa; API luaran lalai kepada kemungkinan null.

Bagaimana untuk menyertai rentetan dengan pemisah dalam C#? (String.Join) Bagaimana untuk menyertai rentetan dengan pemisah dalam C#? (String.Join) Mar 13, 2026 am 12:02 AM

String.Join direka khas untuk penyambungan rentetan. Ia selamat, cekap dan sangat mudah dibaca. Hanya masukkan pembatas dan tatasusunan rentetan, dan elemen nol akan dilangkau secara automatik. Tatasusunan kosong atau null akan mengembalikan rentetan kosong. Pemformatan eksplisit diperlukan untuk mengendalikan jenis bukan rentetan. Dalam senario sensitif prestasi, tatasusunan diluluskan dahulu dan bukannya IEnumerable. StringBuilder sesuai untuk logik yang kompleks.

Bagaimana untuk mengukur masa pelaksanaan dalam C#? (Kelas jam randik) Bagaimana untuk mengukur masa pelaksanaan dalam C#? (Kelas jam randik) Mar 16, 2026 am 12:13 AM

Jam randik.Start() perlu dipanggil untuk kejadian yang tidak dimulakan, jika tidak InvalidOperationException akan dilemparkan; StartNew() ialah kaedah statik yang boleh dibuat dan dimulakan dalam satu langkah, menjadikannya lebih selamat dan lebih biasa digunakan.

Artikel berkaitan