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

.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 代码激活热重载:

dotnet watch

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

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

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

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

dotnet watch --no-hot-reload

二、代码示例

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

 1. VS Code新建Blazor Server project 

dotnet new blazorserver

 

 2. dotnet watch 运行

F:\Tranning\NET6\Blazor>dotnet watch
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:\Tranning\NET6\Blazor\bin\Debug\net6.0\Blazor.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:\Tranning\NET6\Blazor\

       首页显示的内容:

 

 

 3. 修改index.razor中的代码

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

 

 

 

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

 

周国庆

2022/03/23

 

页面下部广告