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
HTMX:n käyttö ASP.NET Coren avulla on hyvä tapa rakentaa dynaamisia verkkosovelluksia minimaalisella JavaScriptilla. HTMX:n avulla voit päivittää sivusi osia ilman koko sivun uudelleenlatausta, jolloin sovelluksesi tuntuu reagoivammalta ja vuorovaikutteisemmalta.
Sitä kutsuin "hybridiverkkosuunnitteluksi", jossa sivu muutetaan täysin palvelimen sivukoodin avulla ja sitten HTMX:n avulla sivun osia päivitetään dynaamisesti.
Tässä artikkelissa näytän, miten voit aloittaa HTMX:n ASP.NET Core -sovelluksessa.
[TÄYTÄNTÖÖNPANO
HTMX - Htmx on JavaScript-paketti, jolla se voidaan helposti sisällyttää projektiisi, on CDN:n käyttö. (Ks. täällä )
<script src="https://unpkg.com/[email protected]" integrity="sha384-QWGpdj554B4ETpJJC9z+ZHJcA/i59TyjxEPXiiUgN2WmTyV5OEZWCD6gQhgkdpB/" crossorigin="anonymous"></script>
Voit tietysti myös ladata kopion ja lisätä sen "manuaalisesti" (tai käyttää LibMan tai npm).
Suosittelen myös Htmx Tag Helper -työkalun asentamista täällä
Nämä molemmat ovat ihmeellisiä. Khalid Abuhakmeh
dotnet add package Htmx.TagHelpers
Ja Htmx Nuget -paketti täällä
dotnet add package Htmx
Tagiauttaja antaa sinun tehdä tämän:
<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>
HUOMAUTUS: Tällä lähestymistavalla on yksi suuri haittapuoli: se ei tuota postilinkille hrefiä. Tämä on ongelma SEO:lle ja saavutettavuudelle. Se tarkoittaa myös, että nämä linkit epäonnistuvat, jos HTMX jostain syystä ei lataudu (CDNs DO menee alas).
Vaihtoehtoinen lähestymistapa on käyttää hx-boost="true"
attribuutti ja normaalit asp.net-ytimen tunnisteavustajat. Katso täällä Lisätietoja hx-boostista (vaikka dokumentteja on vähän).
Tämä tuottaa normaalin hrefin, mutta HTMX ja sisältö ladataan dynaamisesti.
Näin ollen:
<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 toimii hyvin osittaisilla näkymillä. Voit ladata osittaisen näkymän sivullasi olevaan konttiin HTMX:n avulla. Tämä on hienoa, kun lataat osia sivustasi dynaamisesti ilman koko sivun uudelleenlatausta.
Tässä sovelluksessa meillä on Layout.cshtml-tiedostossa kontti, johon haluamme ladata osittaisen näkymän.
<div class="container mx-auto" id="contentcontainer">
@RenderBody()
</div>
Normaalisti se tekee palvelimen sivusisällön, mutta HTMX-tunnisteen avulla näet, että kohdistamme hx-target="#contentcontainer"
joka lataa osittaisen näkymän konttiin.
Projektissamme meillä on BlogView-osittainen näkymä, jonka haluamme ladata konttiin.
Sitten Blog Controllerissa meillä on
[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);
}
Katso täältä, että meillä on HTMX-pyyntö.IsHtmx() -menetelmä, tämä palautuu todeksi, jos pyyntö on HTMX-pyyntö. Jos se on, palautamme osittaisen näkemyksen, ellemme palauta täydellistä näkemystä.
Tämän avulla voimme varmistaa, että tuemme myös suoraa kyselyä vähäisin todellisin ponnistuksin.
Tässä tapauksessa koko näkemyksemme viittaa tähän osittaiseen:
@model Mostlylucid.Models.Blog.BlogPostViewModel
@{
ViewBag.Title = "title";
Layout = "_Layout";
}
<partial name="_PostPartial" model="Model"/>
Ja niin meillä on nyt superyksinkertainen tapa ladata osittainen näkymä sivullemme HTMX:n avulla.