Representación previa de componentes de Razor de ASP.NET Core
Nota:
Esta no es la versión más reciente de este artículo. Para la versión actual, consulte la versión de .NET 9 de este artículo.
Importante
Esta información hace referencia a un producto en versión preliminar, el cual puede sufrir importantes modificaciones antes de que se publique la versión comercial. Microsoft no proporciona ninguna garantía, expresa o implícita, con respecto a la información proporcionada aquí.
Para la versión actual, consulte la versión de .NET 9 de este artículo.
En este artículo se explican los escenarios de representación previa de componentes de Razor para componentes representados por el servidor en Blazor Web App.
La representación previa es el proceso de representación inicial del contenido de la página en el servidor sin habilitar controladores de eventos para controles representados. El servidor genera la interfaz de usuario HTML de la página lo antes posible en respuesta a la solicitud inicial, lo que hace que la aplicación se sienta más sensible a los usuarios. La representación previa también puede mejorar la optimización del motor de búsqueda (SEO) mediante la representación del contenido de la respuesta HTTP inicial que los motores de búsqueda usan para calcular la clasificación de página.
Conservación del estado previamente representado
Si no se conserva el estado representado previamente, se pierde el estado usado durante la representación previa, por lo que se debe volver a crear una vez que la aplicación se haya cargado por completo. Si se crea un estado de forma asincrónica, la interfaz de usuario puede parpadear a medida que se reemplaza la interfaz de usuario prerepresentada cuando se vuelve a representar el componente.
Tenga en cuenta el siguiente componente de contador PrerenderedCounter1
. El componente establece un valor de contador aleatorio inicial durante la representación previa en el método de ciclo de vida OnInitialized
. Una vez establecida la conexión SignalR al cliente, el componente vuelve a representarse y el valor de recuento inicial se reemplaza cuando OnInitialized
se ejecuta una segunda vez.
PrerenderedCounter1.razor
:
@page "/prerendered-counter-1"
@rendermode @(new InteractiveServerRenderMode(prerender: true))
@inject ILogger<PrerenderedCounter1> Logger
<PageTitle>Prerendered Counter 1</PageTitle>
<h1>Prerendered Counter 1</h1>
<p role="status">Current count: @currentCount</p>
<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
@code {
private int currentCount;
protected override void OnInitialized()
{
currentCount = Random.Shared.Next(100);
Logger.LogInformation("currentCount set to {Count}", currentCount);
}
private void IncrementCount() => currentCount++;
}
Ejecute la aplicación e inspeccione el registro desde el componente. A continuación se incluye el resultado del ejemplo.
Nota:
Si la aplicación adopta el enrutamiento interactivo y se llega a la página a través de una navegación mejorada interna, no se produce la representación previa. Por lo tanto, debe realizar una recarga de página completa para el PrerenderedCounter1
componente para ver la salida siguiente. Para obtener más información, consulte la sección Enrutamiento interactivo y representación previa.
info: BlazorSample.Components.Pages.PrerenderedCounter1[0]
currentCount set to 41
info: BlazorSample.Components.Pages.PrerenderedCounter1[0]
currentCount set to 92
El primer recuento registrado se produce durante la representación previa. El recuento se establece de nuevo tras la representación previa cuando se vuelve a representar el componente. También hay un parpadeo en la interfaz de usuario cuando el recuento se actualiza de 41 a 92.
Para conservar el valor inicial del contador durante la representación previa, Blazor es compatible con la persistencia del estado en una página con representación previa usando el servicio PersistentComponentState (y para componentes incrustados en páginas o vistas de Razor Pages o aplicaciones MVC, el Ayudante de etiqueta de estado de componentes persistentes).
Para preservar el estado de representación previa, decida qué estado mantener usando el servicio de PersistentComponentState. PersistentComponentState.RegisterOnPersisting registra una devolución de llamada para conservar el estado del componente antes de que se pause la aplicación. El estado se recupera cuando se reanuda la aplicación.
En el ejemplo siguiente, se muestra el patrón general:
- El marcador de posición
{TYPE}
representa el tipo de datos que se va a conservar. - El marcador de posición
{TOKEN}
es una cadena de identificador de estado. Considere la posibilidad de usarnameof({VARIABLE})
, donde el marcador de posición{VARIABLE}
es el nombre de la variable que contiene el estado. El uso denameof()
del identificador de estado evita el uso de una cadena entre comillas.
@implements IDisposable
@inject PersistentComponentState ApplicationState
...
@code {
private {TYPE} data;
private PersistingComponentStateSubscription persistingSubscription;
protected override async Task OnInitializedAsync()
{
persistingSubscription =
ApplicationState.RegisterOnPersisting(PersistData);
if (!ApplicationState.TryTakeFromJson<{TYPE}>(
"{TOKEN}", out var restored))
{
data = await ...;
}
else
{
data = restored!;
}
}
private Task PersistData()
{
ApplicationState.PersistAsJson("{TOKEN}", data);
return Task.CompletedTask;
}
void IDisposable.Dispose()
{
persistingSubscription.Dispose();
}
}
El siguiente ejemplo de componente de contador conserva el estado del contador durante la representación previa y recupera el estado para inicializar el componente.
PrerenderedCounter2.razor
:
@page "/prerendered-counter-2"
@implements IDisposable
@inject ILogger<PrerenderedCounter2> Logger
@inject PersistentComponentState ApplicationState
<PageTitle>Prerendered Counter 2</PageTitle>
<h1>Prerendered Counter 2</h1>
<p role="status">Current count: @currentCount</p>
<button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
@code {
private int currentCount;
private PersistingComponentStateSubscription persistingSubscription;
protected override void OnInitialized()
{
persistingSubscription =
ApplicationState.RegisterOnPersisting(PersistCount);
if (!ApplicationState.TryTakeFromJson<int>(
nameof(currentCount), out var restoredCount))
{
currentCount = Random.Shared.Next(100);
Logger.LogInformation("currentCount set to {Count}", currentCount);
}
else
{
currentCount = restoredCount!;
Logger.LogInformation("currentCount restored to {Count}", currentCount);
}
}
private Task PersistCount()
{
ApplicationState.PersistAsJson(nameof(currentCount), currentCount);
return Task.CompletedTask;
}
void IDisposable.Dispose() => persistingSubscription.Dispose();
private void IncrementCount() => currentCount++;
}
Cuando se ejecuta el componente, currentCount
solo se establece una vez durante la representación previa. El valor se restaura cuando se vuelve a representar el componente. A continuación se incluye el resultado del ejemplo.
Nota:
Si la aplicación adopta el enrutamiento interactivo y se llega a la página a través de una navegación mejorada interna, no se produce la representación previa. Por lo tanto, debe realizar una recarga de página completa para el PrerenderedCounter2
componente para ver la salida siguiente. Para obtener más información, consulte la sección Enrutamiento interactivo y representación previa.
info: BlazorSample.Components.Pages.PrerenderedCounter2[0]
currentCount set to 96
info: BlazorSample.Components.Pages.PrerenderedCounter2[0]
currentCount restored to 96
Al inicializar componentes con el mismo estado que se usa durante la representación previa, los pasos de inicialización costosos solo se ejecutan una vez. La interfaz de usuario representada también coincide con la que se ha representado previamente, por lo que no se produce ningún parpadeo en el explorador.
El estado preenderado persistente se transfiere al cliente, donde se usa para restaurar el estado del componente. Durante la representación del lado cliente (CSR, InteractiveWebAssembly
), los datos se exponen al explorador y no deben contener información confidencial y privada. Durante la representación interactiva del lado servidor (SSR interactivo, InteractiveServer
), ASP.NET Protección de datos principales garantiza que los datos se transfieren de forma segura. El InteractiveAuto
modo de representación combina webAssembly e interactividad del servidor, por lo que es necesario tener en cuenta la exposición de datos al explorador, como en el caso de CSR.
Componentes incrustados en páginas y vistas (Razor Pages/MVC)
Para componentes incrustados en una página o vista de Razor Pages o una aplicación MVC, debe agregar el Ayudante de etiqueta de estado de componente persistente con la etiqueta <persist-component-state />
HTML dentro de la etiqueta de cierre </body>
del diseño de la aplicación. Esto solo es necesario para Razor Pages y aplicaciones MVC. Para más información, consulte Ayudante de etiqueta de estado de componente persistente en ASP.NET Core.
Pages/Shared/_Layout.cshtml
:
<body>
...
<persist-component-state />
</body>
Enrutamiento interactivo y representación previa
Cuando el componente Routes
no define un modo de representación, la aplicación usa interactividad y navegación por página/componente. Con la navegación por página/componente, la navegación interna† se gestiona mediante el enrutamiento mejorado una vez que la aplicación se vuelve interactiva. †Interna en este contexto significa que el destino de la dirección URL del evento de navegación es un punto de conexión Blazor dentro de la aplicación.
El servicio PersistentComponentState solo funciona en la carga inicial de la página y no en los eventos internos de navegación mejorada.
Si la aplicación realiza una navegación completa (no mejorada) a una página que usa el estado de componente persistente, el estado persistente está disponible para que la aplicación la use cuando se vuelva interactiva.
Si ya se ha establecido un circuito interactivo y se realiza una navegación mejorada a una página que usa el estado de componente persistente, el estado no está disponible en el circuito existente para que el componente use. No hay ninguna representación previa para la solicitud de página interna y el servicio PersistentComponentState no es consciente de que se ha producido una navegación mejorada. No hay ningún mecanismo para entregar actualizaciones de estado a los componentes que ya se están ejecutando en un circuito existente. La razón de esto es que Blazor solo admite el paso del estado del servidor al cliente en el momento en que se inicializa el tiempo de ejecución, no después de que se haya iniciado el tiempo de ejecución.
Se está considerando un trabajo adicional en el marco de Blazor para abordar este escenario para .NET 10 (noviembre de 2025). Para obtener más información y ver las discusiones de la comunidad de soluciones alternativas no admitidas, consulte Compatibilidad con el estado de componente persistente en las navegaciones de página mejoradas (dotnet/aspnetcore
n.º 51584). ‡Las soluciones no oficiales no están autorizadas por Microsoft para usar en aplicaciones Blazor. Usar paquetes, enfoques y código de terceros a su propio riesgo.
Deshabilitar la navegación mejorada, lo que reduce el rendimiento, pero también evita el problema de cargar el estado con PersistentComponentState para las solicitudes de página interna, se trata en ASP.NET Core Blazor enrutamiento y navegación.
Guía de representación previa
La guía de representación previa está organizada en la documentación de Blazor por temas. En los vínculos siguientes se tratan todas las instrucciones de representación previa en toda la documentación establecida por tema:
Aspectos básicos
- OnNavigateAsync se ejecuta dos veces al representar previamente: control de eventos de navegación asincrónicos con
OnNavigateAsync
- Inicio: encabezados de control en código C#
- Control de errores: representación previa de
- SignalR: tamaño del estado de representación previa y SignalRlímite de tamaño del mensaje
- OnNavigateAsync se ejecuta dos veces al representar previamente: control de eventos de navegación asincrónicos con
Componentes
<head>
- Temas del ciclo de vida de los componentes Razor relacionados con la representación previa
- Inicialización de componentes (
OnInitialized{Async}
) - Después de representar el componente (
OnAfterRender{Async}
) - Reconexión con estado después de la representación previa
- Representación previa de la interoperabilidad de JavaScript: esta sección también aparece en los dos artículos de interoperabilidad JS sobre cómo llamar a JavaScript desde .NET y llamar a .NET desde JavaScript.
- Controlar acciones asincrónicas incompletas en la representación: guía para la representación retrasada debido a tareas de ciclo de vida de larga duración durante la representación previa en el servidor.
- Inicialización de componentes (
- Aplicación de ejemplo de componentes de QuickGrid: la aplicación de ejemplo QuickGrid para Blazor está alojada en GitHub Pages. El sitio se carga rápidamente gracias a la representación previa estática mediante el proyecto de GitHub
BlazorWasmPrerendering.Build
mantenido por la comunidad. - Representación previa al integrar componentes en Razor Pages y aplicaciones MVC
Autenticación y autorización
- Mitigación de amenazas del lado servidor: scripting entre sitios (XSS)
- Visualización de contenido no autorizado del lado servidor durante la representación previa con un elemento personalizado
AuthenticationStateProvider
- Blazor WebAssembly de autenticación de componente representado con representación previa
Administración de estado: Control de representación previa: además de la sección Control de representación previa, varias de las otras secciones del artículo incluyen comentarios sobre la representación previa.