0

0

.NET如何使用Blazor开发一个WebAssembly应用_Blazor WebAssembly开发教程

幻夢星雲

幻夢星雲

发布时间:2025-11-17 14:22:02

|

883人浏览过

|

来源于php中文网

原创

blazor webassembly 是 .net 的前端技术,允许用 c# 替代 javascript 构建交互式网页。它通过 webassembly 在浏览器中运行 .net 运行时,无需插件,所有代码在客户端执行。要开始开发,需安装 .net sdk(推荐 6.0 或更高版本)及开发工具(如 visual studio、vs code 等)。使用 dotnet --version 检查 .net 是否安装,若未安装则从官网下载。通过命令 dotnet new blazorwasm -n myblazorapp 创建新项目,进入目录后运行 dotnet run 启动应用,浏览器将显示默认模板页面。项目结构包含 pages(.razor 页面)、shared(共享组件)、wwwroot(静态资源)、program.cs(服务配置)和 app.razor(根组件)。razor 组件结合 html 与 c#,逻辑写在 @code{ } 块中。可创建自定义组件如 helloworld.razor,设置路由 /hello,并通过按钮事件更新时间。应用支持调用 api,httpclient 已预注册,可用 getfromjsonasync 获取数据并反序列化为 c# 对象。发布时使用 dotnet publish -c release -o ./publish 生成静态文件,部署至 nginx、iis 或 github pages 等平台

.net如何使用blazor开发一个webassembly应用_blazor webassembly开发教程

Blazor WebAssembly 是 .NET 提供的一种前端开发技术,允许你使用 C# 代替 JavaScript 来构建交互式网页应用。它直接在浏览器中运行 .NET 运行时(通过 WebAssembly),无需插件,所有代码都在客户端执行。下面是一个完整的入门指南,教你如何从零开始创建一个 Blazor WebAssembly 应用。

准备工作:安装开发环境

要开发 Blazor WebAssembly 应用,你需要安装以下工具:

  • .NET SDK(6.0 或更高版本):推荐使用最新 LTS 版本(如 .NET 8)
  • Visual Studio 2022 / VS Code / JetBrains Rider:任选其一作为开发工具

打开终端或命令提示符,运行以下命令检查是否已安装 .NET:

dotnet --version

如果没有安装,请前往 https://www.php.cn/link/c9f8941c38b7d49a586adf043f2acf21 下载并安装 SDK。

创建 Blazor WebAssembly 项目

使用 .NET CLI 创建新项目非常简单。在命令行中运行:

dotnet new blazorwasm -n MyBlazorApp

这会创建一个名为 MyBlazorApp 的新项目。进入项目目录:

cd MyBlazorApp
dotnet run

启动成功后,浏览器会自动打开并显示默认的 Blazor 模板页面,包含导航菜单、计数器示例和天气数据演示。

项目结构说明

Blazor WebAssembly 项目的典型结构如下:

  • wwwroot/:存放静态资源(CSS、JS、图片等)
  • Pages/:Razor 页面组件(.razor 文件),如 Index.razor、Counter.razor
  • Shared/:共享组件,如 NavMenu.razor、MainLayout.razor
  • Program.cs:应用入口点,配置服务和依赖注入
  • App.razor:根组件,定义路由视图

Razor 组件结合了 HTML 和 C#,使用 @code{ } 块嵌入逻辑。

编写一个简单的自定义组件

Pages 文件夹中创建一个新的 Razor 组件 HelloWorld.razor

@page "/hello"

Hello from Blazor!


当前时间:@DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")

php中级教程之ajax技术
php中级教程之ajax技术

AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。它不是新的编程语言,而是一种使用现有标准的新方法,最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容,不需要任何浏览器插件,但需要用户允许JavaScript在浏览器上执行。《php中级教程之ajax技术》带你快速

下载



@message



@code {
private string message = "点击按钮刷新时间";

private void UpdateTime()
{
message = $"时间已更新:{DateTime.Now:T}";
}
}

保存后,在浏览器中访问 /hello 路径即可看到该页面。点击按钮会触发 C# 方法更新 UI。

处理 HTTP 请求与 API 调用

Blazor WebAssembly 可以调用后端 API。默认项目已注册 IHttpClientFactoryHttpClient

例如,在 Program.cs 中已经包含:

builder.Services.AddScoped(sp => new HttpClient { BaseAddress = new Uri(builder.HostEnvironment.BaseAddress) });

你可以使用 HttpClient 获取 JSON 数据:

@using System.Text.Json
...
@code {
private WeatherForecast[] forecasts;

protected override async Task OnInitializedAsync()
{
try
{
forecasts = await Http.GetFromJsonAsync("sample-data/weather.json");
}
catch (Exception ex)
{
// 处理错误
}
}
}

其中 WeatherForecast 是一个简单的 C# 类,用于反序列化返回的数据。

部署 Blazor WebAssembly 应用

发布前先构建生产版本:

dotnet publish -c Release -o ./publish

生成的文件位于 publish/wwwroot 目录中,可部署到任何静态文件服务器(如 Nginx、IIS、GitHub Pages、Azure Static Web Apps 等)。

注意:Blazor WebAssembly 是单页应用(SPA),需确保服务器配置为将所有未知路径重定向到 index.html,以支持路由功能。

基本上就这些。掌握以上内容后,你可以进一步学习状态管理、身份认证(如 Azure AD、Auth0)、JavaScript 互操作、组件库集成等高级特性。Blazor WebAssembly 让 .NET 开发者能用熟悉的语言构建现代前端应用,适合中小型 SPA 项目或企业内部系统。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

246

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

522

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

610

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

244

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

693

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3618

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

54

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

71

2026.01.13

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号