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
الآن بما أن لدي مجموعة من مقالات المدونات فإن صفحة الاستقبال كانت تطول لذا قررت إضافة آلية استدعاء لمواقع المدونات.
هذا يتماشى مع إضافة كبسولة كاملة لنشرات المدونات لجعل هذا الموقع سريعاً وفعالاً.
[رابعاً -
قررت أن أستخدم واغ بلايدر لتنفيذ آلية الاستدعاء. هذه طريقة عظيمة لتغليف منطق الطقوس وجعله قابلاً لإعادة الاستخدام. هذا استخدامات من Darel O' أُدرج في المشروع كحزمة معدنية.
ثم يضاف هذا إلى _ملفّ sownmports.cshtml file as itإيطالياهو متوفّر إلى الكل.
@addTagHelper *,PaginationTagHelper.AspNetCore
في الـ _(BlogumaryList.cshtml) وجهة نظر جزئية أضفت الرمز التالي لجعل آلية الاستدعاء.
<pager link-url="@Model.LinkUrl"
hx-boost="true"
hx-push-url="true"
hx-target="#content"
hx-swap="show:none"
page="@Model.Page"
page-size="@Model.PageSize"
total-items="@Model.TotalItems" ></pager>
بعض الأشياء الملحوظة هنا:
link-url
هذا إلى توليد صحيح URl لـ. وفي طريقة مؤشر المراقبة الداخلية، يُتخذ هذا الإجراء. var posts = blogService.GetPostsForFiles(page, pageSize);
posts.LinkUrl= Url.Action("Index", "Home");
if (Request.IsHtmx())
{
return PartialView("_BlogSummaryList", posts);
}
وفي متحكم المدونات
public IActionResult Index(int page = 1, int pageSize = 5)
{
var posts = blogService.GetPostsForFiles(page, pageSize);
if(Request.IsHtmx())
{
return PartialView("_BlogSummaryList", posts);
}
posts.LinkUrl = Url.Action("Index", "Blog");
return View("Index", posts);
}
هذا هو set إلى الURl. وهذا يضمن أن مساعد المهبل يمكن أن يعمل لأي من طريقتي المستوى الأعلى.
hx-boost
, hx-push-url
, hx-target
, hx-swap
هذه هي كل خصائص HTMX التي تسمح للناقل بالعمل مع HTMX.
hx-boost="true"
hx-push-url="true"
hx-target="#content"
hx-swap="show:none"
نستعمل هنا hx-boost="true"
هذا يسمح لـ إلى لا حاجة إلى أي تعديلات بالاعتراض هو عادي URL توليد و استخدام الحالي URL.
hx-push-url="true"
إلى ضمان URL هو بوصة المتصفح URL URL التاريخ الذي يسمح مباشرة ربط إلى صفحات.
hx-target="#content"
هذا هو الهدف div الذي سيتم استبداله مع المحتوى الجديد.
hx-swap="show:none"
هذا هو مقايضة تأثير الذي سيستخدم عند استبدال المحتوى. في هذه الحالة يمنع تأثير 'القفز` العادي الذي يستخدم HTMX على المحتوى المقايضة.
أضفت أيضاً أساليب إلى الرئيسيات.cs في دليل / src الخاص بي تسمح لي باستخدام فصول CSS التيل ويند للوصلات المائلة.
.pagination {
@apply py-2 flex list-none p-0 m-0 justify-center items-center;
}
.page-item {
@apply mx-1 text-black dark:text-white rounded;
}
.page-item a {
@apply block rounded-md transition duration-300 ease-in-out;
}
.page-item a:hover {
@apply bg-blue-dark text-white;
}
.page-item.disabled a {
@apply text-blue-dark pointer-events-none cursor-not-allowed;
}
page
, page-size
, total-items
هي الخصائص التي يستعملها مساعد الوسم المائل لتوليد الوصلات الإشباعية.
يتم تمرير هذه إلى وجهة النظر الجزئية من المتحكم.
public IActionResult Index(int page = 1, int pageSize = 5)
هنا يتم تمرير الصفحة و حجم الصفحة من العنوان وتحسب العناصر الإجمالية من خدمة المدونات.
public PostListViewModel GetPostsForFiles(int page=1, int pageSize=10)
{
var model = new PostListViewModel();
var posts = GetPageCache().Values.Select(GetListModel).ToList();
model.Posts = posts.OrderByDescending(x => x.PublishedDate).Skip((page - 1) * pageSize).Take(pageSize).ToList();
model.TotalItems = posts.Count();
model.PageSize = pageSize;
model.Page = page;
return model;
}
هنا ببساطة نحصل على الاعمدة من المخبأ، ونطلبها بالتاريخ ثم نتخطى ونأخذ العدد الصحيح من الاعمدة للصفحة.
كانت هذه إضافة بسيطة للموقع لكنها تجعله أكثر قابلية للاستخدام. إن دمج HTMX يجعل الموقع يشعر بأنه أكثر استجابة بينما لا يضيف المزيد من جافاسكربت إلى الموقع.