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
Att använda HTMX med ASP.NET Core är ett bra sätt att bygga dynamiska webbapplikationer med minimal JavaScript. Med HTMX kan du uppdatera delar av din sida utan att ladda om hela sidan, vilket gör din applikation mer lyhörd och interaktiv.
Det är vad jag brukade kalla "hybrid" webbdesign där du gör sidan helt med server-side-kod och sedan använda HTMX för att uppdatera delar av sidan dynamiskt.
I den här artikeln ska jag visa dig hur du kommer igång med HTMX i en ASP.NET Core-applikation.
HTMX - Htmx är ett JavaScript-paket som det lättaste sättet att inkludera det i ditt projekt är att använda en CDN. (Se också här )
<script src="https://unpkg.com/[email protected]" integrity="sha384-QWGpdj554B4ETpJJC9z+ZHJcA/i59TyjxEPXiiUgN2WmTyV5OEZWCD6gQhgkdpB/" crossorigin="anonymous"></script>
Du kan naturligtvis också ladda ner en kopia och inkludera den "manuellt" (eller använda LibMan eller npm).
Jag rekommenderar också att installera Htmx Tag Helper från här
Dessa är båda från den underbara Khalid Abuhakmeh Ordförande
dotnet add package Htmx.TagHelpers
Och Htmx Nuget-paketet från här
dotnet add package Htmx
Tagghjälparen låter dig göra detta:
<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>
OBS: Detta tillvägagångssätt har en stor nackdel; det producerar inte en href för postlänken. Detta är ett problem för SEO och tillgänglighet. Det betyder också att dessa länkar kommer att misslyckas om HTMX av någon anledning inte laddar (CDNs DO går ner).
En alternativ metod är att använda hx-boost="true"
Attribut och vanliga Asp.net-kärntagghjälpare. Se också här för mer information om hx-boost (även om dokumenten är lite sparsamma).
Detta kommer att ge en normal href men kommer att fångas upp av HTMX och innehållet laddas dynamiskt.
Så här:
<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 fungerar bra med partiella vyer. Du kan använda HTMX för att ladda en delvy i en behållare på din sida. Detta är bra för att ladda delar av din sida dynamiskt utan en hel sida ladda om.
I denna app har vi en behållare i Layout.cshtml-filen som vi vill ladda en partiell vy i.
<div class="container mx-auto" id="contentcontainer">
@RenderBody()
</div>
Normalt återger det serversidans innehåll, men med hjälp av HTMX-taggen kan du se att vi riktar in oss på hx-target="#contentcontainer"
som kommer att lasta den partiella sikten i behållaren.
I vårt projekt har vi bloggenView delvyn som vi vill lasta in i behållaren.
Sedan i bloggen Controller vi har
[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);
}
Du kan se här att vi har HTMX Request.IsHtmx() metod, detta kommer att återvända sant om begäran är en HTMX begäran. Om det är vi returnerar den partiella vyn, om inte vi returnerar den fullständiga vyn.
Med hjälp av detta kan vi se till att vi också stöder direkta frågor med liten verklig ansträngning.
I detta fall hänvisar vi till denna del:
@model Mostlylucid.Models.Blog.BlogPostViewModel
@{
ViewBag.Title = "title";
Layout = "_Layout";
}
<partial name="_PostPartial" model="Model"/>
Och så har vi nu ett super enkelt sätt att ladda partiella vyer på vår sida med hjälp av HTMX.