اندازهی قلم متن
تخمین مدت زمان مطالعهی مطلب:
دو دقیقه
همانطور که در مطلب ایجاد زیرگریدها در jqGrid مشاهده کردید، هرچند این قابلیت برای نمایش لیست سادهای از عناصر مفید است اما ... امکانات آنچنانی را به همراه ندارد. برای مثال صفحه بندی، جستجو، سفارشی سازی عناصر و غیره را به همراه ندارد. اگر علاقمند باشید که این امکانات را نیز اضافه کنید، میتوان این زیرگرید را با یک گرید کامل jqGrid نیز جایگزین کرد. همچنین اگر نیاز بود، این گرید جدید چون یک jqGrid کامل است، باز هم میتوان یک سطح دیگر را به آن افزود و الی آخر.
جایگزین کردن یک Subgrid با یک jqGrid کامل
خلاصهی عملیات جایگزینی یک Subgrid را توسط یک jqGrid کامل، در ذیل مشاهده میکنید:
همانند نمایش subgridهای معمولی، ابتدا subGrid: true باید اضافه شود تا ستونی با ردیفهای + دار، ظاهر شود. اینبار توسط روال رویدادگردان subGridRowExpanded، کنترل نمایش subgrid را در دست گرفته و آنرا با یک jqGrid جایگزین میکنیم.
امضای متد grid1RowExpanded، شامل id یک div است که گرید جدید در آن قرار خواهد گرفت، به همراه Id ردیفی که اطلاعات زیرگرید آن نیاز است از سرور واکشی شود.
بر مبنای subGridId، مانند قبل، یک جدول و یک div را برای نمایش jgGrid و pager آن به صفحه به صورت پویا اضافه میکنیم.
سپس تعاریف jqGrid آن مانند قبل است و نکتهی خاصی ندارد. بدیهی است گرید جدید نیز میتواند در صورت نیاز یک subgrid دیگر داشته باشد.
در اینجا تنها نکتهی مهم آن نحوهی ارسال اطلاعات rowId به سرور است. اکشن متدی که قرار است اطلاعات زیر گرید را تامین کند، یک چنین امضایی دارد:
بنابراین نیاز است که به نحوی rowId را به آن ارسال کرد. مشکل اینجا است که Url.Action یک کد سمت سرور است و rowId یک متغیر سمت کاربر. نمیتوان این متغیر را در کدهای Razor مستقیما قرار داد. اما میتوان یک محل جایگزینی را در کدهای سمت سرور پیش بینی کرد. مثلا js-id. زمانیکه این رشته در صفحه رندر میشود، به صورت معمول و به کمک متد replace جاوا اسکریپت، js-id آنرا با rowId جایگزین میکنیم. به این ترتیب امکان تزریق اطلاعات سمت کاربر به خروجی سمت سرور Razor میسر میشود.
کدهای کامل این مثال را از اینجا میتوانید دریافت کنید:
jqGrid12.zip
جایگزین کردن یک Subgrid با یک jqGrid کامل
خلاصهی عملیات جایگزینی یک Subgrid را توسط یک jqGrid کامل، در ذیل مشاهده میکنید:
$('#list').jqGrid({ caption: "آزمایش دوازدهم", //..........مانند قبل subGrid: true, subGridRowExpanded: grid1RowExpanded }); function grid1RowExpanded(subGridId, rowId) { var subgridTableId = subGridId + "_t"; var pagerId = "p_" + subgridTableId; var container = 'g_' + subGridId; $("#" + subGridId).html('<div dir="rtl" id="' + container + '" style="width:100%; height: 100%">' + '<table id="' + subgridTableId + '" class="scroll"></table><div id="' + pagerId + '" class="scroll"></div>'); var url = '@Url.Action("GetOrderDetails", "Home", routeValues: new { id = "js-id" })' .replace("js-id", encodeURIComponent(rowId)); // تزریق اطلاعات سمت کاربر به خروجی سمت سرور $("#" + subgridTableId).jqGrid({ caption: "ریز اقلام سفارش " + rowId, autoencode: true, //security - anti-XSS url: url, //..........مانند قبل }); }
امضای متد grid1RowExpanded، شامل id یک div است که گرید جدید در آن قرار خواهد گرفت، به همراه Id ردیفی که اطلاعات زیرگرید آن نیاز است از سرور واکشی شود.
بر مبنای subGridId، مانند قبل، یک جدول و یک div را برای نمایش jgGrid و pager آن به صفحه به صورت پویا اضافه میکنیم.
سپس تعاریف jqGrid آن مانند قبل است و نکتهی خاصی ندارد. بدیهی است گرید جدید نیز میتواند در صورت نیاز یک subgrid دیگر داشته باشد.
در اینجا تنها نکتهی مهم آن نحوهی ارسال اطلاعات rowId به سرور است. اکشن متدی که قرار است اطلاعات زیر گرید را تامین کند، یک چنین امضایی دارد:
public ActionResult GetOrderDetails(int id, JqGridRequest request)
کدهای کامل این مثال را از اینجا میتوانید دریافت کنید:
jqGrid12.zip