简介
服务器端呈现 (SSR) 是指服务器生成 HTML 以响应请求。使用 SSR 的应用加载速度很快,因为渲染 UI 的所有艰苦工作都在服务器上完成,而无需下载大型 JavaScript 捆绑包。ASP.NET Core 对带有 MVC 和 Razor 页面的 SSR 现有支持,但这些框架缺乏用于构建可重用的 Web UI 片段的组件模型。这就是开拓者的用武之地!我们正在添加对使用 Blazor 组件生成服务器呈现的 UI 的支持,这些组件也可以扩展到客户端以实现丰富的交互性。
项目体验
首先需要安装 .NET 8预览版最新版
dotnet new web -o WebApp
cd WebApp
- 在项目中添加一个简单的Razor组件:
dotnet new razorcomponent -n MyComponent
- 更新
MyComponent.razor
内容,将其变成一个带有路由的合适的HTML页面;
@page "/"
@implements IRazorComponentApplication<MyComponent>
<!DOCTYPE html>
<html lang="en">
<body>
<h2>Hello Blazor!</h2>
<p>The time is @DateTime.Now.ToShortTimeString(</p>
</body>
</html>
你还需要在这个组件上实现接口IRazorComponentApplication
,该接口目前用于帮助发现应用程序中的组件端点。这个设计可能会在以后的更新中改变,但目前这个接口是必需的。
-
Program.cs中通过调用
.AddRazorComponents(
设置Razor
组件服务builder.Services.AddRazorComponents(;
-
通过调用映射组件的端点。你需要为你的组件添加一个using指令:
MapRazorComponents<TComponent>(
app.MapRazorComponents<WebApp.MyComponent>(;
可路由组件将自动在所驻留的程序集中发现。再次注意,当前必须实现,但此设计可能会在以后的更新中更改。MyComponentTComponentIRazorComponentApplication
- 运行应用程序并浏览到应用程序根目录查看你的组件渲染
但是似乎无法交互,我在使用了点击事件但是没法触发了
MyComponent.razor文件代码
@page "/"
@implements IRazorComponentApplication<MyComponent>
<!DOCTYPE html>
<html lang="en">
<body>
<h2>Hello Blazor!</h2>
<p>The time is @DateTime.Now.ToShortTimeString(</p>
<p>Counter: @counter</p>
<button @onclick="OnClick">run</button>
@code {
private int counter = 0;
private void OnClick(
{
counter++;
}
}
</body>
</html>
运行效果:
来着token的分享
技术交流:737776595