我在jqGrid中使用rowNum时出现问题。我正在尝试使网格只加载我在rowNum中指定的行数。目前,网格正在加载阵列中的所有数据。
这是我的网格:
$(function () {
var width = $(window).width() - 50;
$("#category_grid").jqGrid({
datatype: "local",
width: width,
height: "auto",
search: true,
autowidth: false,
shrinkToFit: true,
colNames: ['ID', 'Name', 'Abbr.', 'Last Update', 'Last Update User', 'Active?', 'Edit'],
colModel: [
{ name: 'ID', width: 5, align: 'center', sorttype: 'int' },
{ name: 'Name', width: 15, align: 'left' },
{ name: 'Abbreviation', width: 10, align: 'left' },
{ name: 'LastUpdateDateTime', width: 8, align: 'left', formatter: dateFix, sorttype: 'date' },
{ name: 'LastUpdateUser', width: 15, align: 'left', sorttype: 'string' },
{ name: 'Active', width: 5, align: 'center', formatter: activeFix },
{ name: 'Edit', width: 5, align: 'center' },
],
rowNum: 20,
rowList: [20, 50, 100, 1000, 100000],
viewrecords: true,
pager: "#gridpager",
sortname: "ID",
sortable: true,
ignoreCase: true,
headertitles: true,
sortorder: "desc",
onSelectRow: function (rowId)
{
var id = $("#category_grid").getCell(rowId, 'ID');
document.location.href = '/Administration/EditCategoryRecord/'+ id;
},
}).navGrid("#gridpager", { edit: false, add: false, del: false }, {}, {}, {}, { multipleSearch: true, multipleGroup: false, showQuery: false, recreateFilter: true });
$("#category_grid").jqGrid('filterToolbar', { stringResult: true, searchOnEnter: true, defaultSearch: 'cn' })
setTimeout(function () { getCategories(); }, 200);
});
function getCategories() {
var data;
var request = $.ajax({
url: "@Url.Action("GetCategories", "Administration")",
type: "GET",
cache: false,
async: true,
data: data,
dataType: "json",
});
request.done(function (orders) {
var thegrid = $("#category_grid");
thegrid.clearGridData();
setTimeout(function () {
for (var i = 0; i < orders.length; i++) {
thegrid.addRowData(i + 1, orders[i]);
}
}, 500);
//alert(thegrid.jqGrid('getGridParam', 'rowNum'));
thegrid.trigger("reloadGrid");
//alert(thegrid.jqGrid('getGridParam', 'rowNum'));
});
request.fail(function (orders) {
alert("The request in the getCategories function failed. The grid will not be filled.");
});
}
这是控制器动作,它向网格发送数据:
public JsonResult GetCategories()
{
// Holds all of the Categories as an array to fill the jqGrid
object data;
// Holds all of the Categories in the db
List<Category> Categories;
// Holds all of the Categories in the db with Usernames as a string instead of an int ID
List<Category> CategoriesWithUserNames = new List<Category>();
// Get all of the current Categories
using (TicketDeskContext context = new TicketDeskContext())
Categories = context.Categories.ToList();
// For every Category, add to the List of Categories with Usernames as a string
foreach (Category Category in Categories)
{
string LastUpdateUser = Functions.GetUserNameByID(Category.LastUpdateUserID);
CategoriesWithUserNames.Add(new Category(Category.ID, Category.Active, Category.Name, Category.Abbreviation, Category.LastUpdateDateTime, LastUpdateUser));
}
// Convert the filtered Category List to the data array
data = CategoriesWithUserNames.ToArray();
// Return the filtered Category List
return Json(data, JsonRequestBehavior.AllowGet);
}
我有什么问题吗?当网格加载时它不会停在20(因为我将rowNum设置为20),它只加载所有数据(目前是27个类别)。
答案 0 :(得分:3)
我通过触发setTimeout中的网格重新加载解决了这个问题。
function getCategories()
{
var data;
var request = $.ajax({
url: "@Url.Action("GetCategories", "Administration")",
type: "GET",
cache: false,
async: true,
data: data,
dataType: "json",
});
request.done(function (orders) {
var thegrid = $("#category_grid");
thegrid.clearGridData();
setTimeout(function () {
for (var i = 0; i < orders.length; i++)
{
thegrid.addRowData(i + 1, orders[i]);
}
// Triggering a grid reload here loads the grid with the number specified in rowNum
thegrid.trigger("reloadGrid");
}, 500);
});
request.fail(function (orders)
{
});
}
答案 1 :(得分:1)
在rowNum:20之后添加loadonce:true。这应该可以解决分页问题。