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.
Saturday, 07 September 2024
//3 minute read
استخدام HTMX مع ASP.NET هي وسيلة كبيرة لبناء تطبيقات شبكية ديناميكية مع الحد الأدنى من جافاسكربت. تسمح لك HTMX بتحديث أجزاء من صفحتك دون إعادة تحميل صفحة كاملة، مما يجعل تطبيقك أكثر استجابة وتفاعلا.
هذا ما كنت أسميه تصميم الويب 'Hibrid' حيث تقوم بترجمة الصفحة بالكامل باستخدام رمز جانب الخادم ومن ثم استخدام HTMX لتحديث أجزاء الصفحة ديناميكيا.
في هذه المقالة، سأريكم كيف تبدأون مع HTMX في تطبيق ASP.net الأساسي.
[رابعاً -
HTMX - Htmx هو a جافاسكربت حزمة طريقة easist لإدراجه في مشروعك هو إلى استخدام a CDN. (انظر: هنا هنا )
<script src="https://unpkg.com/[email protected]" integrity="sha384-QWGpdj554B4ETpJJC9z+ZHJcA/i59TyjxEPXiiUgN2WmTyV5OEZWCD6gQhgkdpB/" crossorigin="anonymous"></script>
يمكنك بطبيعة الحال أيضاً تحميل نسخة وإدراجها'manually' (أو استخدام LibMan أو npm).
أوصي أيضاً أيضاً بتثبيت مُساعد Htmx Tacher من هنا هنا
هذان كلاهما من الـ (السكين)
dotnet add package Htmx.TagHelpers
والـ Htmx حزمة من هنا هنا
dotnet add package Htmx
الـ شارة مساعدة اسمح لـ:
<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>
ملاحظة: لهذا النهج عيب رئيسي واحد؛ فهو لا ينتج هريف لوصلة البريد. وهذه مشكلة تتعلق بتكافؤ فرص الحصول على الخدمات وإمكانية الوصول إليها. هذا يعني أيضاً أن هذه الوصلات ستفشل إذا كان HTMX لسبب ما لا يحمل (CDNs DO يهبط).
النهج البديل هو استخدام hx-boost="true"
و الصفات و المُساعدات الأساسيّة العادية للعلامة. انظر S انظر هنا هنا لمزيد من المعلومات عن Hx-Bostst (بالرغم من أن الأطباء قليلون قليلاً).
هذا سينتج هرف عادي لكن سيتم اعتراضه بواسطة HTMX والمحتوى الذي يتم تحميله بشكل دينامي.
وبناء على ما يلي:
<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 بشكل جيد مع إلى. يمكنك استخدام HTMX لتحميل وجهة نظر جزئية في حاوية على صفحتك. هذا عظيم لأجزاء التحميل من صفحتك بشكل ديناميكي بدون إعادة تحميل صفحة كاملة.
في هذا التطبيق لدينا حاوية في ملف التصميم.cshtml التي نريد تحميل عرض جزئي فيها.
<div class="container mx-auto" id="contentcontainer">
@RenderBody()
</div>
عادة ما يُعطي محتوى جانب الخادم لكن باستخدام مُعَامِل مُعَامِل بطاقة HTMx فيمكنك أن ترى أننا نُوَفّر hx-target="#contentcontainer"
الذي سيحمّل المنظر الجزئي في الحاوية.
في مشروعنا لدينا نظرة BlogView الجزئية التي نريد تحميلها في الحاوية.
ثمّ في المدوّنة نحن عِنْدَنا
[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);
}
يمكنك أن ترى هنا لدينا طلب HTMX. ISHTmx( طريقة، هذا سيعود صحيحاً إذا كان الطلب هو طلب HTMX. وإذا كان الأمر يتعلق بعكس وجهة النظر الجزئية، فإن لم يكن بعكس وجهة النظر الكاملة.
وباستخدام هذا، يمكننا أن نضمن أننا نؤيد أيضاً الاستعلام المباشر مع بذل جهد حقيقي ضئيل.
وفي هذه الحالة، تشير وجهة نظرنا الكاملة إلى هذا الحكم الجزئي:
@model Mostlylucid.Models.Blog.BlogPostViewModel
@{
ViewBag.Title = "title";
Layout = "_Layout";
}
<partial name="_PostPartial" model="Model"/>
ولدينا الآن طريقة بسيطة جداً لتحميل وجهات النظر الجزئية في صفحتنا باستخدام HTMX.