خانه \\ MVC 5 & 6 \\ بررسی Infinite Scroll در ASP.NET MVC بر اساس Jquery Ajax
بررسی Infinite Scroll در ASP.NET MVC بر اساس Jquery Ajax
1395/08/30 - 23:52:15 // MVC 5 & 6 // 0 نظر // 4450 بازدید
در این مقاله به صورت سریع و ساده قصد داریم به بررسی چگونگی پیاده سازی Infinite Scrolling در ASP.NET MVC با کمک Jquery بپردازیم.
بسمه تعالی
بررسی Infinite Scroll در ASP.NET MVC
در این مقاله به صورت سریع و ساده قصد داریم به بررسی چگونگی پیاده سازی Infinite Scrolling در ASP.NET MVC با کمک Jquery بپردازیم.
در ابتدا اجازه بدهید به شرح و صورت مساله بپردازیم. اصلن این Infinite Scroll چیست ؟. پاسخ بسیار ساده است. دیگر برای Scroll شدن صفحه و نمایش داده های جدید و صدا زدن آنها از دیتابیس لازم نیست سیستم شماره گزاری و اجبار کاربر به Click بر روی شماره صفحه یا کلیدهای قبل و بعد و ... باشد. تنها کافی است کاربر با Scroll Down ، به من و شمای برنامه نویس نشان دهد داده های صفحه بعد را به عنوان مثال نیاز دارد.
حال باید دیدچگونه باید این سناریو را پیاده کرد. در ابتدا یک پروژه جدید ASP.NET MVC 5 ایجاد کنید، ولی وضهیت Authentication را روی None قرار دهید تا بیهوده View و Controller اضافی و بی مورد ایجاد نگردد.
برای داشتن دیتا اصولن باید دیتابیس در اختیار داشته باشیم، ولی در این مثال من از یک فایل XML حاوی دیتای ساده متعلق به کتاب استفاده میکنم تا مراحل پیاده سازی ساده تر گردد. بدنه و محتوای فایل XML من به شکل زیر است.
- <book id="bk101">
- <author>Gambardella, Matthew</author>
- <title>XML Developer's Guide</title>
- <genre>Computer</genre>
- <price>44.95</price>
- <publish_date>2000-10-01</publish_date>
- <description>An in-depth look at creating applications with XML.</description>
- </book>
- <book id="bk102">
- <author>Ralls, Kim</author>
- <title>Midnight Rain</title>
- <genre>Fantasy</genre>
- <price>5.95</price>
- <publish_date>2000-12-16</publish_date>
- <description>A former architect battles corporate zombies, an evil sorceress,
- and he own childhood to become queen of the world.</description>
- </book>
برای شروع به Model نیاز داریم که به شکل زیر خواهد بود.
public class Book
{
public string ID { get; set; }
public string Author { get; set; }
public string Title { get; set; }
public string Genre { get; set; }
public string Price { get; set; }
public string PublishDate { get; set; }
public string Description { get; set; }
}
خوب اگر مثلن اطلاعات 5 کتاب نمایش داده شود،با Scroll 5 تای بعدی نمایش داده خواهد شد. در اینجا من BlockSize را 5 و BlockNumber را 1 قرار میدهم و با هر Scroll به این مقدار اضافه شده و 5 تای بعدی نمایش داده خواهد شد.
در این پروژه من درون Model یک کلاس به نام DataManager ساخته ام و از کلیه امور اعم از ایجاد Model و بحث صفحه بندی و ... را درون این کلاس پیاده سازی کرده ام.
- public static class DataManager
- {
-
-
-
-
-
-
- public static List<Book> GetBooks(int BlockNumber, int BlockSize)
- {
- int startIndex = (BlockNumber - 1) * BlockSize;
-
- var filePath = AppDomain.CurrentDomain.BaseDirectory + "testData.xml";
- var doc = XDocument.Load(filePath);
-
- var books = (from p in doc.Descendants("book")
- select new Book
- {
- ID = p.Attributes("id").Single().Value,
- Author = p.Element("author").Value,
- Title = p.Element("title").Value,
- Genre = p.Element("genre").Value,
- Price = p.Element("price").Value,
- PublishDate = p.Element("publish_date").Value,
- Description = p.Element("description").Value,
- }).Skip(startIndex).Take(BlockSize).ToList();
-
- return books;
- }
- }
در متد GetBooks داده ها از فایل XML خوانده شده و سپس بر اساس شماره صفحه محاسبه و از طریق دو Extension Method به نامهای Skip و Take میتوان از روی رکوردها پرش کرد و در عمل صفحه بندی داشت.
حال نوبت به Controller و Action Method ها میرسد که باید به درستی پیاده سازی گردند. به یک PartialView به نام BookList هم نیاز داریم. متد اول به شکل زیر خواهد بود.
[ChildActionOnly]
public ActionResult BookList(List<Book> Model)
{
return PartialView(Model);
}
چون این متد درون متد دیگری صدا زده میشود و نیازی به فراخوانی از بیرون ندارد، آنرا به صورت ChildAction تعریف کرده ایم.
محتویات BookList Partial View آنچنان پیچیده نیست و فقط یک Loop ساده برای نمایش داده هاست.
- @model List<mvcajaxinfinitescroll.Models.Book>
-
- @foreach (var item in Model)
- {
- <div style="height: 300px; background-color: #F3F3F3; margin-bottom: 30px;">
- <div style="padding: 30px; font-size: 25px; color: #7b4f9d">@item.Title</div>
- <div style="padding-left: 30px; font-size: 18px;">Author: @item.Author</div>
- <div style="padding-left: 30px; font-size: 18px;">Genre: @item.Genre</div>
- <div style="padding-left: 30px; font-size: 18px;">Price: @item.Price $</div>
- <div style="padding-left: 30px; font-size: 18px;">Publish Date: @item.PublishDate</div>
- <div style="padding-left: 30px; padding-right: 30px; font-size: 18px;">Description: @item.Description</div>
- </div>
- }
اگر میبینید کمی شلوغ شده، فقط برای CSS و شکل دادن و بهبود نمایش در حالت اجراست، وگرنه از یک Loop ساده چیزی بیشتر وجود ندارد.
خوب Index Action هم بسیار ساده و به شکل زیر خواهد بود.
- public ActionResult Index()
- {
- int BlockSize = 5;
- var books = DataManager.GetBooks(1, BlockSize);
- return View(books);
- }
درون View به شکل زیر میتوان از این متد BookList استفاده کرد.
- <div id="bookListDiv">
- @{Html.RenderAction("BookList", "Home", new { ModelModel = Model });}
- </div>
حال نوبت متد اصلی که از نوع HttpPost است خواهد بود.- public ActionResult InfinateScroll(int BlockNumber)
- {
-
-
-
- int BlockSize = 5;
- var books = DataManager.GetBooks(BlockNumber, BlockSize);
-
- JsonModel jsonModel = new JsonModel();
- jsonModel.NoMoreData = books.Count < BlockSize;
- jsonModel.HTMLString = RenderPartialViewToString("BookList", books);
-
- return Json(jsonModel);
- }
یک Sleep Thread داریم برای کند کردن روال Load داده ها که در حالات واقعی باید حذف شود.
یک مدل جدید به نام JsonModel به شکل زیر ایجاد کنید.
- public class JsonModel
- {
- public string HTMLString { get; set; }
- public bool NoMoreData { get; set; }
- }
فیلد NoMoreData تایین کننده آن است که به صفحه آخر رسیده ایم یا نه و تکلیف HtmlString هم که مشخص است که باید حاوی داده های تولیدی باشد. یک متد به نام RenderPartialViewtoSrting وظیفه تبدیل داده ها به Json را بر عهده دارد که البته راههای دیگری هم برای این امر وجود دارد.
- protected string RenderPartialViewToString(string viewName, object model)
- {
- if (string.IsNullOrEmpty(viewName))
- viewName = ControllerContext.RouteData.GetRequiredString("action");
-
- ViewData.Model = model;
-
- using (StringWriter sw = new StringWriter())
- {
- ViewEngineResult viewResult =
- ViewEngines.Engines.FindPartialView(ControllerContext, viewName);
- ViewContext viewContext = new ViewContext
- (ControllerContext, viewResult.View, ViewData, TempData, sw);
- viewResult.View.Render(viewContext, sw);
-
- return sw.GetStringBuilder().ToString();
- }
- }
خوب حالا نوبت یک Ajax ساده و صدا زدن متد سمت سرور توسط Jquery است .
- <script type="text/javascript">
- var BlockNumber = 2;
- var NoMoreData = false;
- var inProgress = false;
-
- $(window).scroll(function () {
- if ($(window).scrollTop() == $(document).height() -
- $(window).height() && !NoMoreData && !inProgress) {
-
- inProgress = true;
- $("#loadingDiv").show();
-
- $.post("@Url.Action("InfinateScroll",
- "Home")", { "BlockNumber": BlockNumber },
- function (data) {
-
- BlockNumber = BlockNumber + 1;
- NoMoreData = data.NoMoreData;
- $("#bookListDiv").append(data.HTMLString);
- $("#loadingDiv").hide();
- inProgress = false;
- });
- }
- });
- </script>
البته یک Loading هم داریم که یک Div ساده است و نکته خاصی ندارد.
وجود سورس پروژه، درک مبحث را ساده تر میکند، چون به هر حال باید بتوانید آنرا اجرا و نتیجه را مشاهده و از آن در پروژه های دیگر استفاده کنید.
معرفی نویسنده : علی کلاهدوزان
سلام بر دوستان ،
شاید رایج است به عنوان پروفایل کاربر ، چند خطی راجع به خودم بنویسم ، ولی وضعیت کاری و سوابق من با یک جستجوی ساده در گوگل مشخص خواهد شد ، لذا سرتان را با مطالب بی مورد به درد نیاورم بهتر است . اگر نکته خاصی لازم بود بدانید در قسمت "ایلیا سافت در یک نگاه" به احتمال زیاد یافت خواهد شد . جزئیات بیشتر را سوال کنید ، آدرس ایمیل Ali@Kolahdoozan.com همیشه جوابگوی شماست .امیدوارم از مطالب سایت استفاده کرده باشید . شاد و پیروز باشید .