ASP.NET Core 6.0对热重载的支持

2022-04-18 20:13:37 浏览数 (1)

.NET 热重载技术支持将代码更改(包括对样式表的更改)实时应用到正在运行的程序中,不需要重启应用,也不会丢失应用状态。

一、整体介绍

目前 ASP.NET Core 6.0 项目都支持热重载。在以下情况下支持应用的热重载:

1. 仅运行一次的应用启动逻辑代码

    • 中间件,除非代码更新是委托给内联中间件进行的。
    • 已配置的服务。
    • 路由创建和配置,除非代码更新是委托给路由处理程序进行的(例如 OnInitialized)。

2. Blazer应用中,框架将自动触发Blazor组件渲染

3. 在 MVC 和 Razor Pages 应用中,热重载自动触发浏览器刷新

4. 删除 Razor组件参数属性不会导致重新呈现组件。必须重启应用。

Blazor WebAssembly 热重载支持具有以下条件:

  1. 热重载对方法主体的大多数更改做出反应,例如添加、删除和编辑变量、表达式和语句。
  2. 还支持对 lambda 表达式和本地函数的主体进行更改。
  3. 不支持添加新的 lambda 或本地函数、添加新的运算符或关键字表达式。
  4. 不支持更改方法参数的名称。
  5. 不支持方法主体之外的更改。
  6. 在 Visual Studio 2022 GA (17.0) 中,只有在没有调试器的情况下运行时,才支持热重载。

.NET CLI

使用 dotnet watch 代码激活热重载:

代码语言:javascript复制
dotnet watch

若要强制应用重新生成和重启,请使用命令行界面中的键盘组合Ctrl R

进行不受支持的代码编辑时(称为强制编辑), 会询问你是否要重启应用:

  • 是:重启应用。
  • 否:不重启应用,并将应用保持在运行状态而不应用更改。
  • 始终:在发生强制编辑时按需重启应用。
  • 从不:不重启应用,也避免未来出现提示。

若要禁用热重载支持,请将 --no-hot-reload 选项传递给 dotnet watch 命令:

代码语言:javascript复制
dotnet watch --no-hot-reload

二、代码示例

本文中我们使用一个Blazor应用示例一下Hot reload

1. VS Code新建Blazor Server project

代码语言:javascript复制
dotnet new blazorserver

2. dotnet watch 运行

F:TranningNET6Blazor>dotnet watch

代码语言:javascript复制
watch : Hot reload enabled. For a list of supported edits, see https://aka.ms/dotnet/hot-reload. Press "Ctrl   R" to restart.
watch : Building...
  正在确定要还原的项目…
  所有项目均是最新的,无法还原。
  Blazor -> F:TranningNET6BlazorbinDebugnet6.0Blazor.dll
watch : Started
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: https://localhost:7256
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: http://localhost:5249
info: Microsoft.Hosting.Lifetime[0]
      Application started. Press Ctrl C to shut down.
info: Microsoft.Hosting.Lifetime[0]
      Hosting environment: Development
info: Microsoft.Hosting.Lifetime[0]
      Content root path: F:TranningNET6Blazor

首页显示的内容:

3. 修改index.razor中的代码

界面显示也自动跟着刷新了

以上是ASP.NET Core 6.0对热重载的支持的一些介绍。

0 人点赞