component classes
ComponentBase
is the base class for Razor components. It implements IComponent.
Components are generated as C# partial classes. They can either be written as:
- A single file with C#
@code
blocks, HTML markup, and Razor markup, like:
Pages/Counter.razor
@page "/counter"
<PageTitle>Counter</PageTitle>
<h1>Counter</h1>
<p role="status">Current count: @currentCount</p>
<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
@code {
private int currentCount = 0;
private void IncrementCount()
{
currentCount++;
}
}
- Or, HTML and Razor markup in a
.razor
file and C# code in a.cs
code-behind file, like:
Pages/Counter.razor
@page "/counter-partial-class"
<PageTitle>Counter</PageTitle>
<h1>Counter</h1>
<p role="status">Current count: @currentCount</p>
<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
Pages/Counter.razor.cs
namespace BlazorSample.Pages;
// The class MUST be partial:
public partial class CounterPartialClass
{
private int currentCount = 0;
private void IncrementCount()
{
currentCount++;
}
}
base classes
Use @inherits
:Pages/BlazorRocks.razor
@page "/blazor-rocks"
@inherits BlazorRocksBase @*specifies BlazorRocksBase.cs as a base class*@
<h1>@BlazorRocksText</h1> @*this string is defined in the base class*@
nested components
Components can include other components by declaring them in HTML.
This Heading
component…Shared/Heading.razor
@* If @page "/heading" were included here, this component would be accessible at /heading and /heading-example. *@
<h1 style="font-style:@headingFontStyle">Heading Example</h1>
@code {
private string headingFontStyle = "italic";
}
…can be used in this example as an HTML tag:Pages/HeadingExample.razor
@page "/heading-example"
<Heading />