AspNetCore.Docs/aspnetcore/blazor/index.md

268 lines
16 KiB
Markdown
Raw Normal View History

2021-08-09 03:43:46 +08:00
---
2022-03-15 17:53:00 +08:00
title: ASP.NET Core Blazor
2021-08-09 03:43:46 +08:00
author: guardrex
description: Explore ASP.NET Core Blazor, a way to build interactive client-side web UI with .NET in an ASP.NET Core app.
monikerRange: '>= aspnetcore-3.1'
ms.author: riande
ms.custom: "mvc"
2022-11-09 00:43:50 +08:00
ms.date: 11/08/2022
2021-08-09 03:43:46 +08:00
uid: blazor/index
---
2022-03-15 17:53:00 +08:00
# ASP.NET Core Blazor
2021-08-09 03:43:46 +08:00
[!INCLUDE[](~/includes/not-latest-version.md)]
2023-04-04 23:06:06 +08:00
2021-08-09 03:43:46 +08:00
*Welcome to Blazor!*
2023-09-08 00:33:04 +08:00
:::moniker range=">= aspnetcore-8.0"
2023-09-09 04:04:32 +08:00
Blazor is a [.NET](/dotnet/standard/tour) frontend web framework that supports both server-side rendering and client interactivity in a single programming model:
2023-09-08 00:33:04 +08:00
:::moniker-end
:::moniker range="< aspnetcore-8.0"
2021-08-09 03:43:46 +08:00
Blazor is a framework for building interactive client-side web UI with [.NET](/dotnet/standard/tour):
2023-09-08 00:33:04 +08:00
:::moniker-end
2022-02-12 20:00:03 +08:00
:::moniker range=">= aspnetcore-6.0"
2021-08-09 03:43:46 +08:00
* Create rich interactive UIs using [C#](/dotnet/csharp/) instead of [JavaScript](https://www.javascript.com).
* Share server-side and client-side app logic written in .NET.
* Render the UI as HTML and CSS for wide browser support, including mobile browsers.
* Integrate with modern hosting platforms, such as [Docker](/dotnet/standard/microservices-architecture/container-docker-introduction/index).
2022-02-12 20:00:03 +08:00
* Build hybrid desktop and mobile apps with .NET and Blazor.
:::moniker-end
2022-02-17 08:50:14 +08:00
:::moniker range="< aspnetcore-6.0"
2022-02-12 20:00:03 +08:00
* Create rich interactive UIs using [C#](/dotnet/csharp/) instead of [JavaScript](https://www.javascript.com).
* Share server-side and client-side app logic written in .NET.
* Render the UI as HTML and CSS for wide browser support, including mobile browsers.
* Integrate with modern hosting platforms, such as [Docker](/dotnet/standard/microservices-architecture/container-docker-introduction/index).
:::moniker-end
2021-08-09 03:43:46 +08:00
Using .NET for client-side web development offers the following advantages:
* Write code in C# instead of JavaScript.
* Leverage the existing .NET ecosystem of [.NET libraries](/dotnet/standard/class-libraries).
* Share app logic across server and client.
* Benefit from .NET's performance, reliability, and security.
* Stay productive on Windows, Linux, or macOS with a development environment, such as [Visual Studio](https://visualstudio.microsoft.com/) or [Visual Studio Code](https://code.visualstudio.com/).
2021-08-09 03:43:46 +08:00
* Build on a common set of languages, frameworks, and tools that are stable, feature-rich, and easy to use.
> [!NOTE]
> For a Blazor quick start tutorial, see [Build your first Blazor app](https://dotnet.microsoft.com/learn/aspnet/blazor-tutorial/intro).
2021-08-09 03:43:46 +08:00
## Components
Blazor apps are based on *components*. A component in Blazor is an element of UI, such as a page, dialog, or data entry form.
Components are .NET C# classes built into [.NET assemblies](/dotnet/standard/assembly/) that:
* Define flexible UI rendering logic.
* Handle user events.
* Can be nested and reused.
* Can be shared and distributed as [Razor class libraries](xref:razor-pages/ui-class) or [NuGet packages](/nuget/what-is-nuget).
2023-09-08 00:33:04 +08:00
The component class is usually written in the form of a [Razor](xref:mvc/views/razor) markup page with a `.razor` file extension. Components in Blazor are formally referred to as *Razor components*, informally as *Blazor components*. Razor is a syntax for combining HTML markup with C# code designed for developer productivity. Razor allows you to switch between HTML markup and C# in the same file with [IntelliSense](/visualstudio/ide/using-intellisense) programming support in Visual Studio.
2021-08-09 03:43:46 +08:00
Blazor uses natural HTML tags for UI composition. The following Razor markup demonstrates a component (`Dialog.razor`) that displays a dialog and processes an event when the user selects a button:
```razor
<div class="card" style="width:22rem">
<div class="card-body">
<h3 class="card-title">@Title</h3>
<p class="card-text">@ChildContent</p>
<button @onclick="OnYes">Yes!</button>
</div>
</div>
@code {
[Parameter]
public RenderFragment? ChildContent { get; set; }
2021-08-09 03:43:46 +08:00
[Parameter]
public string? Title { get; set; }
2021-08-09 03:43:46 +08:00
private void OnYes()
{
Console.WriteLine("Write to the console in C#! 'Yes' button selected.");
}
}
```
In the preceding example, `OnYes` is a C# method triggered by the button's `onclick` event. The dialog's text (`ChildContent`) and title (`Title`) are provided by the following component that uses this component in its UI.
2023-09-09 04:03:59 +08:00
The `Dialog` component is nested within another component using an HTML tag. In the following example, the `Index` component (`Index.razor`) uses the preceding `Dialog` component. The tag's `Title` attribute passes a value for the title to the `Dialog` component's `Title` property. The `Dialog` component's text (`ChildContent`) are set by the content of the `<Dialog>` element. When the `Dialog` component is added to the `Index` component, [IntelliSense in Visual Studio](/visualstudio/ide/using-intellisense) speeds development with syntax and parameter completion.
:::moniker range=">= aspnetcore-8.0"
```razor
@page "/"
@attribute [RenderModeServer]
<h1>Hello, world!</h1>
<p>
Welcome to your new app.
</p>
<Dialog Title="Learn More">
Do you want to <i>learn more</i> about Blazor?
</Dialog>
```
:::moniker-end
:::moniker range="< aspnetcore-8.0"
2021-08-09 03:43:46 +08:00
```razor
@page "/"
<h1>Hello, world!</h1>
<p>
Welcome to your new app.
</p>
<Dialog Title="Learn More">
Do you want to <i>learn more</i> about Blazor?
</Dialog>
```
2023-09-09 04:03:59 +08:00
:::moniker-end
2021-08-09 03:43:46 +08:00
The dialog is rendered when the `Index` component is accessed in a browser. When the button is selected by the user, the browser's developer tools console shows the message written by the `OnYes` method:
2021-08-13 21:31:50 +08:00
![Dialog component rendered in the browser nested inside of the Index component. The browser developer tools console shows the message written by C# code when the user selects the Yes! button in the UI.](~/blazor/index/_static/dialog.png)
2021-08-09 03:43:46 +08:00
Components render into an in-memory representation of the browser's [Document Object Model (DOM)](https://developer.mozilla.org/docs/Web/API/Document_Object_Model/Introduction) called a *render tree*, which is used to update the UI in a flexible and efficient way.
2023-09-08 00:33:04 +08:00
:::moniker range=">= aspnetcore-8.0"
## Blazor Web Apps
Blazor Web Apps provide a component-based architecture with server-side rendering and full client-side interactivity in a single project, where you can switch between server-side and client-side rendering modes and even mix them in the same page.
2023-09-12 20:58:21 +08:00
When a Blazor Web App uses interactivity with server rendering, the server generates HTML in response to a request and sends it to the browser. The page loads fast because UI rendering is performed quickly on the server without the need to download a large JavaScript bundle or wait for the establishment of a [SignalR](xref:signalr/introduction) connection to the client.
2023-09-08 00:33:04 +08:00
*Streaming rendering* can improve the user experience with SSR when long-running asynchronous tasks are required to fully render a page. Initially, Blazor renders the entire page for the browser with placeholder content. The asynchronous operations execute on the server. After the operations are complete, the updated content is sent to the browser on the same response connection and patched into page. The benefit of this approach is that the main layout of the app renders as quickly as possible.
2023-09-12 20:58:21 +08:00
Blazor Web Apps also support interactivity with client rendering that relies on a .NET runtime running on [WebAssembly](https://webassembly.org). For more information on WebAssembly, see the [Blazor WebAssembly](#blazor-webassembly) section.
2023-09-08 00:33:04 +08:00
After rendering is complete, interactivity on the client can adopt either or both of the following techniques, even in the same page:
* UI updates and JavaScript interop calls handled over a SignalR connection. The runtime stays on the server and handles:
* Executing the app's C# code.
* UI events from the browser that are sent to the server.
* Applying UI updates to a rendered component that are sent back by the server.
* Rich interactivity and UI updates handled by a .NET runtime running in the browser on WebAssembly.
* C# code files and Razor files are compiled into .NET assemblies.
* The assemblies and the [.NET runtime](/dotnet/framework/get-started/overview) are downloaded to the browser.
* Blazor bootstraps the .NET runtime and configures the runtime to load the assemblies for the app. The Blazor WebAssembly runtime uses JavaScript interop to handle DOM manipulation and browser API calls.
<!--
IMAGE for Blazor Web Apps
![XXXXXXXXX](~/blazor/index/_static/blazor-web-app.png)
-->
:::moniker-end
:::moniker range="< aspnetcore-8.0"
2021-08-09 03:43:46 +08:00
## Blazor Server
Blazor Server provides support for hosting Razor components on the server in an ASP.NET Core app. UI updates are handled over a [SignalR](xref:signalr/introduction) connection.
2021-08-09 03:43:46 +08:00
The runtime stays on the server and handles:
* Executing the app's C# code.
* Sending UI events from the browser to the server.
* Applying UI updates to a rendered component that are sent back by the server.
2021-08-09 03:43:46 +08:00
The connection used by Blazor Server to communicate with the browser is also used to handle JavaScript interop calls.
2021-08-13 21:31:50 +08:00
![Blazor Server runs .NET code on the server and interacts with the Document Object Model on the client over a SignalR connection](~/blazor/index/_static/blazor-server.png)
2021-08-09 03:43:46 +08:00
Blazor Server apps render content differently than traditional models for rendering UI in ASP.NET Core apps using Razor views or Razor Pages. Both models use the [Razor language](xref:mvc/views/razor) to describe HTML content for rendering, but they significantly differ in *how* markup is rendered.
2021-08-09 03:43:46 +08:00
When a Razor Page or view is rendered, every line of Razor code emits HTML in text form. After rendering, the server disposes of the page or view instance, including any state that was produced. When another request for the page occurs, the entire page is rerendered to HTML again and sent to the client.
2021-08-09 03:43:46 +08:00
2023-09-08 00:33:04 +08:00
Blazor Server produces a graph of components to display similar to an HTML or XML DOM. The component graph includes state held in properties and fields. Blazor evaluates the component graph to produce a binary representation of the markup, which is sent to the client for rendering. After the connection is made between the client and the server, the component's static prerendered elements are replaced with interactive elements. Prerendering the content on the server makes the app feel more responsive on the client.
2021-08-09 03:43:46 +08:00
After the components are interactive on the client, UI updates are triggered by user interaction and app events. When an update occurs, the component graph is rerendered, and a UI *diff* (difference) is calculated. This diff is the smallest set of DOM edits required to update the UI on the client. The diff is sent to the client in a binary format and applied by the browser.
2021-08-09 03:43:46 +08:00
A component is disposed after the user navigates away from the component.
2021-08-09 03:43:46 +08:00
2023-09-08 00:33:04 +08:00
:::moniker-end
## Blazor WebAssembly
Blazor WebAssembly is a [single-page app (SPA) framework](/dotnet/architecture/modern-web-apps-azure/choose-between-traditional-web-and-single-page-apps) for building interactive client-side web apps with .NET.
Running .NET code inside web browsers is made possible by [WebAssembly](https://webassembly.org) (abbreviated `wasm`). WebAssembly is a compact bytecode format optimized for fast download and maximum execution speed. WebAssembly is an open web standard and supported in web browsers without plugins. WebAssembly works in all modern web browsers, including mobile browsers.
WebAssembly code can access the full functionality of the browser via JavaScript, called *JavaScript interoperability*, often shortened to *JavaScript interop* or *JS interop*. .NET code executed via WebAssembly in the browser runs in the browser's JavaScript sandbox with the protections that the sandbox provides against malicious actions on the client machine.
![Blazor WebAssembly runs .NET code in the browser with WebAssembly.](~/blazor/index/_static/blazor-webassembly.png)
When a Blazor WebAssembly app is built and run:
* C# code files and Razor files are compiled into .NET assemblies.
* The assemblies and the [.NET runtime](/dotnet/framework/get-started/overview) are downloaded to the browser.
2023-09-08 00:33:04 +08:00
* Blazor WebAssembly bootstraps the .NET runtime and configures the runtime to load the assemblies for the app. The Blazor WebAssembly runtime uses JavaScript interop to handle DOM manipulation and browser API calls.
The size of the published app, its *payload size*, is a critical performance factor for an app's usability. A large app takes a relatively long time to download to a browser, which diminishes the user experience. Blazor WebAssembly optimizes payload size to reduce download times:
* Unused code is stripped out of the app when it's published by the [Intermediate Language (IL) Trimmer](xref:blazor/host-and-deploy/configure-trimmer).
* HTTP responses are compressed.
* The .NET runtime and assemblies are cached in the browser.
2022-02-12 20:00:03 +08:00
:::moniker range=">= aspnetcore-6.0"
## Blazor Hybrid
Hybrid apps use a blend of native and web technologies. A *Blazor Hybrid* app uses Blazor in a native client app. Razor components run natively in the .NET process and render web UI to an embedded Web View control using a local interop channel. WebAssembly isn't used in Hybrid apps. Hybrid apps encompass the following technologies:
2022-02-12 20:00:03 +08:00
* [.NET Multi-platform App UI (.NET MAUI)](/dotnet/maui/what-is-maui): A cross-platform framework for creating native mobile and desktop apps with C# and XAML.
* [Windows Presentation Foundation (WPF)](/dotnet/desktop/wpf/overview/): A UI framework that is resolution-independent and uses a vector-based rendering engine, built to take advantage of modern graphics hardware.
* [Windows Forms](/dotnet/desktop/winforms/overview/): A UI framework that creates rich desktop client apps for Windows. The Windows Forms development platform supports a broad set of app development features, including controls, graphics, data binding, and user input.
For more information on creating Blazor Hybrid apps with the preceding frameworks, see the following articles:
* <xref:blazor/hosting-models>
* <xref:blazor/hybrid/index>
:::moniker-end
2021-08-09 03:43:46 +08:00
## JavaScript interop
For apps that require third-party JavaScript libraries and access to browser APIs, components interoperate with JavaScript. Components are capable of using any library or API that JavaScript is able to use. C# code can [call into JavaScript code](xref:blazor/js-interop/call-javascript-from-dotnet), and JavaScript code can [call into C# code](xref:blazor/js-interop/call-dotnet-from-javascript).
## Code sharing and .NET Standard
Blazor implements the [.NET Standard](/dotnet/standard/net-standard), which enables Blazor projects to reference libraries that conform to .NET Standard specifications. .NET Standard is a formal specification of .NET APIs that are common across .NET implementations. .NET Standard class libraries can be shared across different .NET platforms, such as Blazor, .NET Framework, .NET Core, Xamarin, Mono, and Unity.
APIs that aren't applicable inside of a web browser (for example, accessing the file system, opening a socket, and threading) throw a <xref:System.PlatformNotSupportedException>.
## Additional resources
* [WebAssembly](https://webassembly.org)
* <xref:blazor/hosting-models>
2022-02-10 21:42:04 +08:00
* <xref:blazor/tutorials/signalr-blazor>
2021-08-09 03:43:46 +08:00
* <xref:blazor/js-interop/call-javascript-from-dotnet>
* <xref:blazor/js-interop/call-dotnet-from-javascript>
* [mono/mono GitHub repository](https://github.com/mono/mono)
2021-08-09 03:43:46 +08:00
* [C# Guide](/dotnet/csharp/)
* <xref:mvc/views/razor>
* [HTML](https://www.w3.org/html/)
* [Awesome Blazor](https://github.com/AdrienTorris/awesome-blazor) (Links to community-maintained Blazor resources)
* [Blazor samples GitHub repository (`dotnet/blazor-samples`)](https://github.com/dotnet/blazor-samples)