NOTE: Apart from
(and even then it's questionable, I'm Scottish). These are machine translated in languages I don't read. If they're terrible please contact me.
You can see how this translation was done in this article.
Thursday, 01 August 2024
//3 minute read
El uso de HTMX con ASP.NET Core es una gran manera de construir aplicaciones web dinámicas con JavaScript mínimo. HTMX le permite actualizar partes de su página sin una recarga completa de la página, haciendo que su aplicación se sienta más sensible e interactiva.
Es lo que solía llamar diseño web 'híbrido' donde se representa la página completamente utilizando el código del lado del servidor y luego utilizar HTMX para actualizar partes de la página de forma dinámica.
En este artículo, te mostraré cómo empezar con HTMX en una aplicación ASP.NET Core.
HTMX - Htmx es un paquete JavaScript de la manera más fácil de incluirlo en su proyecto es utilizar un CDN. (Véase aquí )
<script src="https://unpkg.com/[email protected]" integrity="sha384-QWGpdj554B4ETpJJC9z+ZHJcA/i59TyjxEPXiiUgN2WmTyV5OEZWCD6gQhgkdpB/" crossorigin="anonymous"></script>
Por supuesto, también puede descargar una copia e incluirla'manualmente' (o utilizar LibMan o npm).
También recomiendo instalar el Htmx Tag Helper desde aquí
Estos dos son de la maravillosa Khalid Abuhakmeh
dotnet add package Htmx.TagHelpers
Y el paquete Htmx Nuget de aquí
dotnet add package Htmx
El ayudante de etiqueta le permite hacer esto:
<a hx-controller="Blog" hx-action="Show" hx-push-url="true" hx-get hx-target="#contentcontainer" hx-route-slug="@Model.Slug"
class="block font-body text-lg font-semibold text-primary transition-colors hover:text-green dark:text-white dark:hover:text-secondary">@Model.Title</a>
NOTA: Este enfoque tiene un inconveniente importante; no produce un href para el enlace post. Este es un problema para el SEO y la accesibilidad. También significa que estos enlaces fallarán si HTMX por alguna razón no se carga (los CDNS DO bajan).
Un enfoque alternativo es el uso de la hx-boost="true"
Atributos y ayudantes de etiquetas asp.net core normales. Ver aquí para más información sobre hx-boost (aunque los documentos son un poco escasos).
Esto producirá una href normal, pero será interceptado por HTMX y el contenido cargado dinámicamente.
Por lo tanto, lo siguiente:
<a asp-controller="Blog" asp-action="Show" hx-boost="true" hx-target="#contentcontainer" asp-route-slug="@Model.Slug"
class="block font-body text-lg font-semibold text-primary transition-colors hover:text-green dark:text-white dark:hover:text-secondary">@Model.Title</a>
HTMX funciona bien con vistas parciales. Puede utilizar HTMX para cargar una vista parcial en un contenedor de su página. Esto es ideal para cargar partes de su página dinámicamente sin una recarga de página completa.
En esta aplicación tenemos un contenedor en el archivo Layout.cshtml en el que queremos cargar una vista parcial.
<div class="container mx-auto" id="contentcontainer">
@RenderBody()
</div>
Normalmente renderiza el contenido del lado del servidor, pero usando el ayudante de etiquetas HTMX sobre usted puede ver que nos dirigimos hx-target="#contentcontainer"
que cargará la vista parcial en el contenedor.
En nuestro proyecto tenemos la vista parcial de BlogView que queremos cargar en el contenedor.
Entonces en el Controlador de Blog que tenemos
[Route("{slug}")]
[OutputCache(Duration = 3600)]
public IActionResult Show(string slug)
{
var post = blogService.GetPost(slug);
if(Request.IsHtmx())
{
return PartialView("_PostPartial", post);
}
return View("Post", post);
}
Puede ver aquí que tenemos el método HTMX Request.IsHtmx(), esto regresará true si la solicitud es una solicitud HTMX. Si es así devolvemos la vista parcial, si no devolvemos la vista completa.
Utilizando esto podemos asegurarnos de que también apoyamos la consulta directa con poco esfuerzo real.
En este caso nuestro punto de vista completo se refiere a este parcial:
@model Mostlylucid.Models.Blog.BlogPostViewModel
@{
ViewBag.Title = "title";
Layout = "_Layout";
}
<partial name="_PostPartial" model="Model"/>
Y ahora tenemos una manera súper simple de cargar vistas parciales en nuestra página usando HTMX.